表一、运算符与特殊字符
| 运算符 | 描述 | |
/ | 选择子元素,返回左侧元素的直接子元素;如果"/"位于最左侧表示选择根结点的直接子元素 | |
// | 递归下降,不论深度,搜索指定的元素;如果位于最左侧表示从根结点出发递归下降搜索指定元素 | |
. | 表示当前元素 | |
* | 通配符,选择任意元素,不考虑名字 | |
@ | 取得属性值,作为属性名的前缀 | |
@* | 通配符,选择任意属性,不考虑名字 | |
: | 名字作用范围分隔符,将名字作用范围前缀与元素或属性名分隔开来 | |
!* | 在相关节点上应用指定方法 | |
()* | 分组,明确指定优先顺序 | |
[] | 应用过滤样式 | |
[]* | 下标运算符,用于在集合中指示元素 |
表二、逻辑运算符
| 可选方式 | 描述 | |
and $and$ 或 && | 逻辑与 | |
or $or$ 或 || | 逻辑或 | |
not() $not$ | 逻辑非 |
表三、关系运算符
| 可选方式 | 描述 | |
= 或 $eq$ | 相等 | |
= 或 $ieq$ | 相等(不区分大小写) | |
!= 或 $ne$ | 不等 | |
$ine$ | 不等(不区分大小写) | |
< 或 $lt$ | 小于 | |
$ilt$ | 小于(不区分大小写) | |
<= 或 $le$ | 小于等于 | |
$ile$ | 小于等于(不区分大小写) | |
> 或 $gt$ | 大于 | |
$igt$ | 大于(不区分大小写) | |
>= 或 $ge$ | 大于等于 | |
$ige$ | 大于等于(不区分大小写) | |
$all$ | 集合运算符,如果集合中所有项目均满足条件则返回"真" | |
$any$ | 集合运算符,如果集合中任意项目满足条件则返回"真" | |
| | 集合运算符,返回两个集合的联合 |
示例一:
从个人简历中寻找具有具有"WEB开发"技能的人的姓名与E-Mail。假设文档结构如下所示:
<document>
<resume>
<name>name</name>
<sex>sex</sex>
<birthday>birthday</birthday>
<skill>skill1</skill>
<skill>skill2</skill2>
…
<skill>skilln</skill>
</resume>
<resume>
…
</resume>
…
</document>
为从以上结构的个人简历中寻找出所有具有WEB开发"技能的人的姓名与E-Mail的XSL文档结构如下:
<TABLE border="1" cellspacing="0">
<TH>姓名</TH><TH>E-Mail</TH>
<xsl:for-each select="resume [$any$skill="WEB开发"]">
<TR><TD><xsl:value-of select="name"/></TD>
<TD><xsl:value-of select="E-Mail"/></TD>
</TR>
</xsl:for-each>
</TABLE>
说明:
1.[ ] ── 表示选择条件,只有满足条件的个人简历才被显示。
2.$any$ ── 由于每个人有多种技能,故加$any$作为前缀,以使每个人所有技能都能被比较。
3.skill='WEB开发' ── 筛选条件。
示例二、
仍上面的XML文档为例,如果欲选择1977/1/1之前出生的人的姓名、技能与E-Mail,相应的XSL文档结构如下(假定生日格式为yyyy/mm/dd):
<TABLE border="1" cellspacing="0">
<TH>姓名</TH><TH>技能</TH><TH>E-Mail</TH>
<xsl:for-each select="resume[birthday$lt$"1977/1/1"]">
<TR>
<TD><xsl:value-of select="name"/></TD>
<TD>
<xsl:value-of select="skill[0]"/>
<xsl:for-each select="skill[index()>0]">、
<xsl:value-of select="."/>
</xsl:for-each>
</TD>
<TD><xsl:value-of select="E-Mail"/></TD>
</TR>
</xsl:for-each>
</TABLE>
说明:
1.birthday $lt$ '1977/1/1' ── 搜索条件,在此处使用"< "会错误,故使用"$lt$"表示小于。
2.skill [0] ── 表示选择skill的第一项。
3.skill [index()>0] ── 表示选择skill的第二项以后(包括第二项)的项目。
4.xsl:value-of select="." ── 表示选择当前标记的值。
相信大家应该注意到,在前面以及本次的例子中出现了一些函数,如index()、formatIndex()、childNumber(),也许大家还不完全明了其中的含义吧?敬请关注下一课。
本期学习XSL样式方法,即可用于XSL元素<xsl:for-each>、<xsl:value-of>、<xsl:template>的select属性、<xsl:apply-templates>的match属性、<xsl:if>、<xsl:when>的test属性中,对元素的范围进行筛选,从而提供更大的灵活性。
XML与DHTML(动态HTML)一样,这些节点都是一个个对象,而且这些对象都是有层次的,从根节点开始构成一颗层次清淅的树状结构,这就形成了文档对象模型DOM(Document Object Model),通过对象的属性、方法来达到访问控制XML节点的目的。
我们这里不打算就XML的DOM逐一详细阐述,因为这完全可以写成一个篇幅较多的教程,我们先就一些常见的方法作一些讨论,以期对DOM的对象方法有一个大致的了解。
注:从本期开始,所有示例不再提供完整源代码,如有不明白之处,请仔细阅读前面七期、并动手练手。
一、end()
含义:返回集合中最后一个元素。
示例:输出最后一份简历
假定XML文件格式为:
……<resume>…</resume>……<resume>…</resume>……
相应XSL文件内容为:
<xsl:for-each select="resume[end()]">……</xsl:for-each>
或:
<xsl:templates match="resume[end()]">……</xsl:templates>
或:
<xsl:apply-template select="resume[end()]">……</xsl:apply-template>
二、index()
含义:返回该元素在集合中的位置,返回值是一整数,其中第一个元素返回0。
示例:返回前面三份简历。
resume[index()$le$3]
注意:index()是与父元素相关的,请看下例:
<x>
<y/>
<y/>
</x>
<x>
<y/>
<y/>
</x>
返回所有<x>中的第一个<y>
x/y[index()=0] 或x/y[0]
三、nodeName()
含义:返回元素的名字,即标记名。
示例:选择任意元素,假如其名字(即标记名)等于"name":
*[nodeName()='name'] 或 *[name]
四、number()
含义:将值转换为数值形式,如果不是数值则返回空,要求参数。
示例:年龄(age)小于30岁的人的简历(resume):
resume[number(age)$lt$30] 或 resume[age$lt$30]
五、nodeType()
含义:返回结点类型,结果为是数值。以下是返回值列表:
| 结点类型 | 结点类型值 | 结点的字符形式描述 |
| Element | 1 | 'element' |
| Element Attribute | 2 | 'attribute' |
| Markup-Delimited Region of Text | 3 | 'text' |
| Processing Instruction | 7 | 'processing_instruction' |
| Comment | 8 | 'comment' |
| Document Entity | 9 | 'document' |
六、value()
含义:返回元素或属性的值。
示例:value()是元素或属性的缺省方法,以下表示是等价:
name!value()="NAME" 与 name="NAME"
@attr="attribute_value" 与 @attr="attribute_value"
注:@是属性前缀,@attr表示是属性attr
七、attribute()
含义:返回所有属性结点的集合,等价于"@*"。
示例:寻找所有的resume元素,满足条件至少有一个属性的值为"ABC":
resume[$any$attribute()='ABC'] 或 resume[$any$@*='ABC']
寻找所有的resume元素,满足条件至少有一个子元素有一个属性的值为"ABC":
resume[$any$*/attribute()='ABC'] 或 resume[$any$*/@*='ABC']
八
【中国下载站】【设为主页】【收藏本页】【打印本文】【回到顶部】【关闭此页】