• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    XSL简明教程(5)XSL的索引
    原著:Jan Egil Refsnes 翻译:阿捷

    五. XSL 的索引


    如果我需要将元素的显示按一定的顺序排列,应该如何建立XSL的索引呢?

    我们还是来看前面的例子,还是这段代码:


    ?xml version="1.0" encoding="ISO8859-1" ?>

    CATALOG>

    CD>

    TITLE>Empire Burlesque/TITLE>

    ARTIST>Bob Dylan/ARTIST>

    COUNTRY>USA/COUNTRY>

    COMPANY>Columbia/COMPANY>

    PRICE>10.90/PRICE>

    YEAR>1985/YEAR>

    /CD>

    .

    .

    .


    当XML文档被转换成HTML文件,索引应该同时建立。简单的办法就是给你的for-each元素增加一个order-by属性,就象这样:

    xsl:for-each select="CATALOG/CD" order-by="+ ARTIST">

    order-by属性带有一个"+"或者"-" 的符号,用来定义索引的方式,是升序还是降序排列。符号后面的名字就是要索引的关键字。

    例如(cd_catalog_sort.xsl):

    ?xml version='1.0'?>

    xsl:stylesheet xmlns:xsl="http://www.w3.org/TR/WD-xsl">

    xsl:template match="/">

    html>

    body>

    table border="2" bgcolor="yellow">

    tr>

    th>Title/th>

    th>Artist/th>

    /tr>

    xsl:for-each select="CATALOG/CD" order-by="+ ARTIST">

    tr>

    td>xsl:value-of select="TITLE"/>/td>

    td>xsl:value-of select="ARTIST"/>/td>

    /tr>

    /xsl:for-each>

    /table>

    /body>

    /html>

    /xsl:template>

    /xsl:stylesheet>


    最后,我们用下面的HTML代码来显示索引结果,你可以自己尝试一下。

    html>

    body>

    script language="javascript">

    // Load XML

    var xml = new ActiveXObject("Microsoft.XMLDOM")

    xml.async = false

    xml.load("cd_catalog.xml")


    // Load the XSL

    var xsl = new ActiveXObject("Microsoft.XMLDOM")

    xsl.async = false

    xsl.load("cd_catalog_sort.xsl")


    // Transform

    document.write(xml.transformNode(xsl))

    /script>


    /body>

    /html>

    上一篇:XSL简明教程(4)在服务器端的实现
    下一篇:XSL简明教程(6)XSL过滤和查询
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    XSL简明教程(5)XSL的索引 XSL,简明教程,的,索引,XSL,