位置:海鸟网 > IT > XML >

如何实现XML+XSL+javascript数据排序

数据排序模版
<?xml version="1.0" encoding="gb2312" ?>
<xsl:stylesheet version="1.1" xmlns:xsl="" xmlns:fo="">
    <xsl:output method="html" />
    <xsl:param name="queryParam" select="''" />
    <xsl:template match="/guestbook">
        <table border="0">
            <tbody>
                <tr>
                    <td>
                        <table width="400" border="0">
                            <tbody>                             
                                <xsl:apply-templates select="article">
                                    <xsl:sort select="datadate" order="descending" />
                                </xsl:apply-templates>                                  
                            </tbody>
                        </table>
                    </td>
                </tr>
            </tbody>
        </table>
    </xsl:template>
    <!--文章列表模版:-->
    <xsl:template match="article">
        <xsl:choose>
            <xsl:when test="position() mod 2 = 1">
                <tr bgcolor="#cccccc">
                    <th align="left" width="50">作者</th>
                    <th align="left" width="50">
                        <xsl:value-of select="author" />
                    </th>
                    <th align="left" width="100">发表时间</th>
                    <th align="left" width="50">
                        <xsl:value-of select="datadate" />
                    </th>
                </tr>
                <tr bgcolor="#cccccc">
                    <td colspan="4">
                        <xsl:value-of select="content" />
                    </td>
                </tr>
            </xsl:when>
            <xsl:otherwise>
                <tr>
                    <th align="left" width="50">作者</th>
                    <th align="left" width="50">
                        <xsl:value-of select="author" />
                    </th>
                    <th align="left" width="100">发表时间</th>
                    <th align="left" width="50">
                        <xsl:value-of select="datadate" />
                    </th>
                </tr>
                <tr>
                    <td colspan="4">
                        <xsl:value-of select="content" />
                    </td>
                </tr>
            </xsl:otherwise>
        </xsl:choose>
    </xsl:template>
</xsl:stylesheet>

数据文件
<?xml version="1.0" encoding="gb2312"?>
<guestbook>
  <article id="73a7a287-aef6-4d35-ac2c-638ca3233be6">
    <author>guest</author>
    <datadate>20060812</datadate>
    <content>asdfsad</content>
  </article>
  <article id="84957008-4cb4-4c96-bafa-775dd33e10cf">
    <author>guest</author>
    <datadate>20060812</datadate>
    <content>fffff</content>
  </article>
  <article id="91426bb3-3bbf-4176-be66-c92cb79bb171">
    <author>guest</author>
    <datadate>20060812</datadate>
    <content>fffff</content>
  </article>
  <article id="8e3bda3f-7d6e-4ae3-af0a-740a884cbf06">
    <author>guest</author>
    <datadate>20060812</datadate>
    <content>asdf</content>
  </article>
  <article id="d6528172-cd03-4333-bb42-0121effca2ff">
    <author>guest</author>
    <datadate>20060812</datadate>
    <content>asdf</content>
  </article>
  <article id="cd30a893-f0aa-44be-b56b-32a1aa44717a">
    <author>guest</author>
    <datadate>20060812</datadate>
    <content>asdf</content>
  </article>
  <article id="b47ca7e6-93e0-4992-97fa-78ea557b0252">
    <author>guest</author>
    <datadate>20060812</datadate>
    <content>asdf</content>
  </article>
  <article id="2070cb5d-e225-46f5-95ca-3dea33f9d42f">
    <author>guest</author>
    <datadate>20060812</datadate>
    <content>aa</content>
  </article>
</guestbook>

由于前面已经介绍了如何通过JS+XSL将XML转换为HTML故这里将不再坳述。读者只需要读懂排序模版文件即可。