欢迎您访问我爱IT技术网,今天小编为你分享的编程技术是:【XSL简明教程(3)在客户端的实现】,下面是详细的分享!
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简明教程(3)在客户端的实现,下面是编辑为你推荐的有价值的用户互动:
相关问题:哪位仁兄给我传一份《自动控制原理》 胡寿松 自动...
答:这个您参考下 >>详细
相关问题:服务端怎样发消息给客户端;java实现!要求客户端...
答:1. Server代码: package com.javacodegeeks.android.androidsocketserver;import java.io.BufferedReader;import java.... >>详细
相关问题:求数字电子技术基础简明教程3第三版全部课后练习答案
答:zrdiy电子学习网有http://tieba.baidu.com/f?kw=zrdiy%B5%E7%D7%D3&fr=home不能直接发网址所以用百度转下 >>详细
- 评论列表(网友评论仅供网友表达个人看法,并不表明本站同意其观点或证实其描述)
-
