快精灵印艺坊 您身边的文印专家
广州名片 深圳名片 会员卡 贵宾卡 印刷 设计教程
产品展示 在线订购 会员中心 产品模板 设计指南 在线编辑
 首页 名片设计   CorelDRAW   Illustrator   AuotoCAD   Painter   其他软件   Photoshop   Fireworks   Flash  

 » 彩色名片
 » PVC卡
 » 彩色磁性卡
 » 彩页/画册
 » 个性印务
 » 彩色不干胶
 » 明信片
   » 明信片
   » 彩色书签
   » 门挂
 » 其他产品与服务
   » 创业锦囊
   » 办公用品
     » 信封、信纸
     » 便签纸、斜面纸砖
     » 无碳复印纸
   » 海报
   » 大篇幅印刷
     » KT板
     » 海报
     » 横幅

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 的控制语句
    微笑服务 优质保证 索取样品