XSL简明教程(3)在客户端的实现

教程|客户端

<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />

 
三. 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><?xml:namespace prefix = st1 ns = "urn:schemas-microsoft-com:office:smarttags" />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文件中。

 

时间: 2025-01-12 23:49:16

XSL简明教程(3)在客户端的实现的相关文章

XSL简明教程(3)在客户端的实现_XML/RSS

原著:Jan Egil Refsnes 翻译:阿捷 三. XSL--在客户端的实现 1.JavaScript解决方案 在上面的章节中我们已经解释了XSL是如何将XML转换成HTML文件.方法就是在XML文档的头部加入一个XSL样式表信息,然后让浏览器执行转换过程. 这种方法在大部分情况下都做得很好,但是在不支持XML的浏览器中就无法正确显示了. 一个更好的更全面的解决方案是使用Javascript来实现XML到HTML的转换.但是使用JavaScript必须得到以下功能支持: a.允许Javas

XSL简明教程目录

XSL简明教程(1)XSL入门 XSL简明教程(2)XSL转换 XSL简明教程(3)在客户端的实现 XSL简明教程(4)在服务器端的实现 XSL简明教程(5)XSL的索引 XSL简明教程(6)XSL过滤和查询 了解WEB页面工具语言XML(一)背景 了解WEB页面工具语言XML(二)定义 了解WEB页面工具语言XML(三)支持工具 了解WEB页面工具语言XML(四)应用分类 了解WEB页面工具语言XML(五)好处 了解WEB页面工具语言XML(六)展望

XSL简明教程(1)XSL入门

教程   一. XSL入门 二. XSL的转换 三. XSL --- 在客户端的实现 四: XSL --- 在服务器端的实现 五. XSL 的索引 六. XSL 的过滤和查询 七. XSL 的控制语句 一. XSL入门 1.XSL---XML的样式表 HTML网页使用预先确定的标识(tags),这就是说所有的标记都有明确的含义,例如<p>是另起一行<h1>是标题字体.所有的浏览器都知道如何解析和显示HTML网页.然而,XML没有固定的标识,我们可以建立我们自己需要的标识,所以浏览器

XSL简明教程(2)XSL转换

教程|转换   二.XSL的转换 <?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />   1.将XML转换成HTML XSL是如何将XML文档转换成HTML文件的呢?我们来看一个例子,下面是XML文档的一部分:   <?xml version="1.0" encoding="ISO8859-1" ?> <CATALO

XSL简明教程(7)XSL 的控制语句

教程|控制|语句   七. XSL 的控制语句<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />   1.条件语句if...then XSL同样还有条件语句(呵呵~~好厉害吧,象程序语言一样).具体的语法是增加一个xsl:if元素,类似这样 <xsl:if match=".[ARTIST='Bob Dylan']"> ... some out

XSL简明教程(6)XSL过滤和查询

教程   六. XSL的过滤和查询 <?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />   如果我们希望只显示满足一定的条件的XML数据应该怎么做呢?还是上面的例子代码,我们只需要在xsl:for-each元素的select属性中加入参数就可以,类似: <xsl:for-each select="CATALOG/CD[ARTIST='Bob Dylan']&

XSL简明教程(5)XSL的索引

教程|索引   五. XSL 的索引 <?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />   如果我需要将元素的显示按一定的顺序排列,应该如何建立XSL的索引呢? 我们还是来看前面的例子,还是这段代码:   <?xml version="1.0" encoding="ISO8859-1" ?> <CATALOG>

XSL简明教程(4)在服务器端的实现

服务器|教程 <?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />  四: XSL --- 在服务器端的实现   1.兼容所有的浏览器 在上面一章我们介绍了可以通过JavaScript调用浏览器的XML parser(解析软件)来转换XML文档.但是这个方案依然有个问题:如果浏览器没有XML parser插件怎么办?(注:IE5内自带XML parser) 为了使我们的XML

XSL简明教程_XML/RSS

一. XSL入门 1.XSL---XML的样式表 HTML网页使用预先确定的标识(tags),这就是说所有的标记都有明确的含义,例如<p>是另起一行<h1>是标题字体.所有的浏览器都知道如何解析和显示HTML网页.然而,XML没有固定的标识,我们可以建立我们自己需要的标识,所以浏览器不能自动解析它们,例如<table>可以理解为表格,也可以理解为桌子.由于XML的可扩展性,使我们没有一个标准的办法来显示XML文档.为了控制XML文档的显示,我们有必要建立一种机制,CSS