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

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    XSL简明教程

    一. XSL入门

    1.XSL---XML的样式表

    HTML网页使用预先确定的标识(tags),这就是说所有的标记都有明确的含义,例如p>是另起一行h1>是标题字体。所有的浏览器都知道如何解析和显示HTML网页。
    然而,XML没有固定的标识,我们可以建立我们自己需要的标识,所以浏览器不能自动解析它们,例如table>可以理解为表格,也可以理解为桌子。由于XML的可扩展性,使我们没有一个标准的办法来显示XML文档。
    为了控制XML文档的显示,我们有必要建立一种机制,CSS就是其中的一种,但是XSL(eXtensible Stylesheet Language)是显示XML文档的首选样式语言,它比CSS更适合于XML。

    2.XSL --- 不仅仅是一种样式表

    XSL由两部分组成:

    一是转化XML文档;二是格式化XML文档。

    如果你不理解这个意思,可以这样想:XSL是一种可以将XML转化成HTML的语言,一种可以过滤和选择XML数据的语言,一种能够格式化XML数据的语言。(比如用红色显示负数。)

    3.XSL --- 它能做什么?

    XSL可以被用来定义XML文档如何显示,可以将XML文档转换成能被浏览器识别的HTML文件,通常的,XSL是通过将每一个XML元素"翻译"为HTML元素,来实现这种转换的。

    XSL能够向输出文件里添加新的元素,或则移动元素。XSL也能够重新排列或者索引数据,它可以检测并决定哪些元素被显示,显示多少。

    4.XSL在IE5中的显示

    注意:IE5.0中,并不能完全兼容W3C组织发布的最新XSL标准。因为IE5.0是在XSL标准最终确定以前发布的。微软已经承诺在IE5.5中修正。 二.XSL的转换
      1.将XML转换成HTML

    XSL是如何将XML文档转换成HTML文件的呢?我们来看一个例子,下面是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文件作为HTML的模板将XML数据转换为HTML文件: ?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>
      在上面的代码中, xsl:for-each元素的作用是定位XML文档中的哪些元素需要按以下模板显示。select属性用来定义源文件中的元素名。指定属性的这种语法又称为XML
    Pattern(模式),类似文件子目录的表示形式。xsl:value-of元素用来在当前层次中插入子元素的内容模板。

    因为XSL样式表自身也是一个XML文档,因此,XSL文件的开头以一个XML声明开始。 xsl:stylesheet元素用来声明这是一个样式表文件。xsl:template
    match="/">语句表示XML的源文档在当前目录下。

    如果为XML文档加上XSL样式表,看下面代码第2行,你的浏览器就可以精确的将XML 文档转换为HTML文件。 ?xml version="1.0" encoding="ISO8859-1" ?>
    ?xml-stylesheet type="text/xsl" href="cd_catalog.xsl"?>
    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--在客户端的实现
      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文件中。
    上一篇:实例讲解:开发SWING的XML框架(2)
    下一篇:XHTML 1.0:标记新的开端
  • 相关文章
  • 

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

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

    XSL简明教程 XSL,简明教程,XSL,简明教程,