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

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

    三. XSL--在客户端的实现


    1.JavaScript解决方案

    在上面的章节中我们已经解释了XSL是如何将XML转换成HTML文件。方法就是在XML文档的头部加入一个XSL样式表信息,然后让浏览器执行转换过程。

    这种方法在大部分情况下都做得很好,但是在不支持XML的浏览器中就无法正确显示了。

    一个更好的更全面的解决方案是使用Javascript来实现XML到HTML的转换。但是使用JavaScript必须得到以下功能支持:

    a.允许Javascript代替浏览器进行细节检测;

    b.根据不同的需要和不同的浏览器使用不同的样式表。

    对于XSL来说这是完全可行的。设计XSL的目标之一就是允许将一种格式转换成另一种格式,支持不同的浏览器,支持不同的用户需求。未来的浏览器的重要任务就是在客户端执行XSL的转换工作。


    2.一个具体的实例

    下面是我们上面提到的一个XML文档(cd_catalog.xml)例子的部分代码:

    ?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>

    .

    .

    .

    下面是完整的XSL文件(cd_catalog.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">

    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>


    注意,现在XML文件还没有加入XSL样式表,还没有被转换成HTML文件。

    下面是用JavaSript来实现最后转换的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.xsl")


    // Transform

    document.write(xml.transformNode(xsl))

    /script>


    /body>

    /html>


    上面代码中使用了Javascript,如果你不知道如何写JavaScript,您最好专门学习一下。

    第一段代码建立一个Microsoft Parser(XMLDOM)解析的对象,并将XML文档读入内存;第二段代码建立另外一个对象并导入XSL文档;最后一行代码将XML文档用XSL文档转换,并将结果输出到HTML文件中。

    上一篇:XSL简明教程(2)XSL转换
    下一篇:XSL简明教程(4)在服务器端的实现
  • 相关文章
  • 

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

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

    XSL简明教程(3)在客户端的实现 XSL,简明教程,在,客户端,