XSL简明教程(3)在客户端的实现
三. 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文件中。
返回类别: 教程 上一教程: 将Recordset作为XML保存 下一教程: XMLHTTP 对象及其方式简介
您可以阅读与"XSL简明教程(3)在客户端的实现"相关的教程: · XSL简明教程(4)在服务器端的实现 · XSL简明教程(5)XSL的索引 · XSL简明教程(2)XSL转变 · XSL简明教程(1)XSL入门 · XSL简明教程(7)XSL 的控制语句
|