XSL简明教程

最近在网上找了一些关于XSL的教程,整理了一下,大家可以参考参考 

 

XSL 简明教程
一.   XSL入门
1.XSL---XML
的样式表
HTML
网页使用预先确定的标识(tags),这就是说所有的标记都有明确的含义,例如<p>是另起一行<h1>是标题字体。所有的浏览器都知道如何解析和显示HTML网页。
然而,XML没有固定的标识,我们可以建立我们自己需要的标识,所以浏览器不能自动解析它们,例如<table>可以理解为表格,也可以理解为桌子。由于XML的可扩展性,使我们没有一个标准的办法来显示XML文档。为了控制XML文档的显示,我们有必要建立一种机制,CSS就是其中的一种,但是XSL(eXtensible Stylesheet Language)是显示XML文档的首选样式语言,它比CSS更适合于XML。
2.XSL ---
不仅仅是一种样式表
XSL
由两部分组成:
一是转化XML文档;二是格式化XML文档。
如果你不理解这个意思,可以这样想:XSL是一种可以将XML转化成HTML的语言,一种可以过滤和选择XML数据的语言,一种能够格式化XML数据的语言。(比如用红色显示负数。)
3.XSL ---
它能做什么?
XSL
可以被用来定义XML文档如何显示,可以将XML文档转换成能被浏览器识别的HTML文件,通常的,XSL是通过将每一个XML元素"翻译"为HTML元素,来实现这种转换的。
XSL
能够向输出文件里添加新的元素,或则移动元素。XSL也能够重新排列或者索引数据,它可以检测并决定哪些元素被显示,显示多少。
4.XSL
在IE5中的显示
注意:IE5.0中,并不能完全兼容W3C组织发布的最新XSL标准。因为IE5.0是在XSL标准最终确定以前发布的。微软已经承诺在IE5.5中修正。
二.XSL的转换
1. XML 转换成 HTML
XSL
是如何将 XML 文档转换成 HTML 文件的呢?我们来看一个例子,下面是 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 文件作为 HTML 的模板将 XML 数据转换为 HTML 文件:
<?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>
在上面的代码中, xsl:for-each 元素的作用是定位 XML 文档中的哪些元素需要按以下模板显示。 select 属性用来定义源文件中的元素名。指定属性的这种语法又称为 XML
Pattern(
模式 ) ,类似文件子目录的表示形式。 xsl:value-of 元素用来在当前层次中插入子元素的内容模板。
因为 XSL 样式表自身也是一个 XML 文档,因此, XSL 文件的开头以一个 XML 声明开始。 xsl:stylesheet 元素用来声明这是一个样式表文件。 <xsl:template
match="/">
语句表示 XML 的源文档在当前目录下。
如果为 XML 文档加上 XSL 样式表,看下面代码第 2 行,你的浏览器就可以精确的将 XML 文档转换为 HTML 文件。
<?xml version="1.0" encoding="ISO8859-1" ?>
<?xml-stylesheet type="text/xsl" href="cd_catalog.xsl"?>
<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--在客户端的实现
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 --- 在服务器端的实现
1. 兼容所有的浏览器
在上面一章我们介绍了可以通过 javascript 调用浏览器的 XML parser( 解析软件 ) 来转换 XML 文档。但是这个方案依然有个问题:如果浏览器没有 XML
parser
插件怎么办? ( 注: IE5 内自带 XML parser)
为了使我们的 XML 数据能被所有的浏览器正确显示,我们不得不在服务器端将 XML 转换成纯 HTML 代码,再输出给浏览器。
这也是使用 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 文件为 HTML 文件的原代码:
<%
'Load the XML
set xml = Server.CreateObject("Microsoft.XMLDOM")
xml.async = false
xml.load(Server.MapPath("cd_catalog.xml"))
'Load the XSL
set xsl = Server.CreateObject("Microsoft.XMLDOM")
xsl.async = false
xsl.load(Server.MapPath("cd_catalog.xsl"))
Response.Write(xml.transformNode(xsl))
%>
注意:我们这里的例子采用的是 ASP 文件,用 VBScript 编写的。如果您不了解 ASP 或者 VBScript ,建议阅读有关书籍。 ( 当然,也可以采用其他的语言编写服务器端程序 )
第一段代码建立一个 Microsoft Parser(XMLDOM) 解析的对象,并将 XML 文档读入内存;第二段代码建立另外一个对象并导入 XSL 文档;最后一行代码将 XML 文档用 XSL 文档转换,并将结果输出到 HTML 文件中。
五. XSL 的索引
如果我需要将元素的显示按一定的顺序排列,应该如何建立 XSL 的索引呢?
我们还是来看前面的例子,还是这段代码:
<?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>
XML 文档被转换成 HTML 文件,索引应该同时建立。简单的办法就是给你的 for-each 元素增加一个 order-by 属性,就象这样:
<xsl:for-each select="CATALOG/CD" order-by="+ ARTIST">
order-by
属性带有一个 "+" 或者 "-" 的符号,用来定义索引的方式,是升序还是降序排列。符号后面的名字就是要索引的关键字。
例如 (cd_catalog_sort.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" order-by="+ ARTIST">
<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>
最后,我们用下面的 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_sort.xsl")
// Transform
document.write(xml.transformNode(xsl))
</script>
</body>
</html>
六. XSL的过滤和查询
如果我们希望只显示满足一定的条件的 XML 数据应该怎么做呢?还是上面的例子代码,我们只需要在 xsl:for-each 元素的 select 属性中加入参数就可以,类似:
<xsl:for-each select="CATALOG/CD[ARTIST='Bob Dylan']">
参数的逻辑选择有:
= (
等于 )
=! (
不等于 )
&LT&
小于
&GT&
大于等于
和前面同样的例子 (cd_catalog_sort.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[ARTIST='Bob Dylan']">
<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>
你可以自己测试一下,看到的结果有什么不同。
七. XSL 的控制语句
1. 条件语句 if...then
XSL
同样还有条件语句 ( 呵呵 ~~ 好厉害吧,象程序语言一样 ) 。具体的语法是增加一个 xsl:if 元素,类似这样
<xsl:if match=".[ARTIST='Bob Dylan']">
... some output ...
</xsl:if>
上面的例子改写成为:
<?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">
<xsl:if match=".[ARTIST='Bob Dylan']">
<tr>
<td><xsl:value-of select="TITLE"/></td>
<td><xsl:value-of select="ARTIST"/></td>
</tr>
</xsl:if>
</xsl:for-each>
</table>
</body>
</html>
</xsl:template>
</xsl:stylesheet>
2. XSL Choose
choose
的用途是出现多个条件,给出不同显示结果。具体的语法是增加一组 xsl:choose,xsl:when,xsl:otherwise 元素:
<xsl:choose>
<xsl:when match=".[ARTIST='Bob Dylan']">
... some code ...
</xsl:when>
<xsl:otherwise>
... some code ....
</xsl:otherwise>
</xsl:choose>
上面的例子改写成为:
<?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>
<xsl:choose>
<xsl:when match=".[ARTIST='Bob Dylan']">
<td bgcolor="#ff0000"><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>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值