test.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>100.90</price> <year>1985</year> </cd> <cd> <title>atitle</title> <artist>dqd</artist> <country>CH</country> <company>Columbia</company> <price>99.90</price> <year>2017</year> </cd> <cd> <title>kaoyan</title> <artist>zx</artist> <country>CH</country> <company>Columbia</company> <price>10.90</price> <year>2017</year> </cd> </catalog> cdcatalog.xsl: <?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>100.90</price> <year>1985</year> </cd> <cd> <title>atitle</title> <artist>dqd</artist> <country>CH</country> <company>Columbia</company> <price>99.90</price> <year>2017</year> </cd> <cd> <title>kaoyan</title> <artist>zx</artist> <country>CH</country> <company>Columbia</company> <price>10.90</price> <year>2017</year> </cd> </catalog>
when和choose的使用:
<?xml version="1.0" encoding="ISO-8859-1"?> <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> <xsl:choose> <xsl:when test="price > 10"> <td bgcolor="#ff00ff"> <xsl:value-of select="artist"/></td> </xsl:when> <xsl:when test="price > 9"> <td bgcolor="#cccccc"> <xsl:value-of select="artist"/></td> </xsl:when> <xsl:otherwise> <td><xsl:value-of select="artist"/></td> </xsl:otherwise> </xsl:choose> </tr> </xsl:for-each> </table> </body> </html> </xsl:template> </xsl:stylesheet>
其中的select属性是根据XPath语法进行找到对应的xml节点的。
假如我们的浏览器不能支持XSLT,我们就需要使用客户端的js来将xml文件转化为xhtml文件了,请注意,这个 XML 文件没有包含对 XSL 文件的引用。
<html> <body> <script type="text/javascript"> // Load XML var xml = new ActiveXObject("Microsoft.XMLDOM") xml.async = false xml.load("test.xml") // Load XSL var xsl = new ActiveXObject("Microsoft.XMLDOM") xsl.async = false xsl.load("cdcatalog.xsl") // Transform document.write(xml.transformNode(xsl)) </script> </body> </html>
又如果浏览器没有XML解析器,js解析的方法也是不能解决xml格式转化的,我们必须在服务器上对 XML 文档进行转换,然后将其作为 XHMTL 发送到浏览器。XSLT 的设计目标之一是使数据在服务器上从一种格式转换到另一种格式成为可能,并向所有类型的浏览器返回可读的数据。 请注意,这个 XML 文件没有包含对 XSL 文件的引用。
这是在服务器上把 XML 文件转换为 XHTML 的源代码:
<% 'Load XML set xml = Server.CreateObject("Microsoft.XMLDOM") xml.async = false xml.load(Server.MapPath("test.xml")) 'Load XSL set xsl = Server.CreateObject("Microsoft.XMLDOM") xsl.async = false xsl.load(Server.MapPath("cdcatalog.xsl")) 'Transform file Response.Write(xml.transformNode(xsl)) %>
第一段代码创建了微软的 XML 解析器的一个实例,然后把 XML 文件载入了内存。第二段代码创建了解析器的另一个实例,然后把这个 XSL 文件载入了内存。最后一行代码使用 XSL 文档转换了 XML 文档,并把结果作为 XHTML 发送到您的浏览器。任务完成!