XSLT 转换

创建于 2024-12-03 / 35
字体: [默认] [大] [更大]

实例研究:如何使用XSLT将XML转换为XHTML?

这个例子的细节将在下一章中解释。


正确的样式表声明

将文档声明为XSL样式表的根元素是<xsl:stylesheet>或者<xsl:transform>.

注释: <xsl:stylesheet> 和 <xsl:transform> 完全同义,两者都可以使用!

根据W3C XSLT建议声明XSL样式表的正确方法是:

<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">

or:

<xsl:transform version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">

要访问XSLT元素、属性和特性,我们必须在文档顶部声明XSLT名称空间。

这个 xmlns:xsl="http://www.w3.org/1999/XSL/Transform" 指向正式的W3C XSLT命名空间。如果使用此命名空间,还必须包含属性 version="1.0".


从原始XML文档开始

我们要将以下XML文档("cdcatalog.xml"):

<?xml version="1.0" encoding="UTF-8"?>
<catalog>
  <cd>
    <title>Empire Burlesque</title>
    <artist>Bob Dylan</artist>
    <country>USA</country>
    <company>Columbia</company>
    <price>10.90</price>
    <year>1985</year>
  </cd>
.
.
</catalog>

在IE、Chrome、Firefox、Safari和Opera中查看XML文件: 打开XML文件(单击下面的链接)-XML文档将显示带有颜色编码的根元素和子元素(Safari中除外)。通常,在元素的左侧有一个加号(+)或减号(-),可以单击它来展开或折叠元素结构。 提示:要查看原始XML源,请右键单击XML文件,然后选择"View Source"!

View "cdcatalog.xml"



创建XSL样式表

然后使用转换模板创建XSL样式表("cdcatalog.xsl"):

<?xml version="1.0" encoding="UTF-8"?>

<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">

<xsl:template match="/">
  <html>
  <body>
  <h2>My CD Collection</h2>
  <table border="1">
    <tr bgcolor="#9acd32">
      <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>

View "cdcatalog.xsl"


将XSL样式表链接到XML文档

将XSL样式表引用添加到XML文档("cdcatalog.xml"):

<?xml version="1.0" encoding="UTF-8"?>
<?xml-stylesheet type="text/xsl" href="cdcatalog.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>
.
.
</catalog>

如果您有一个与XSLT兼容的浏览器,它可以很好地将XML转换为XHTML。

查看结果

以上例子的细节将在下一章中解释。



0 人点赞过