注意:文章中$$符号只有一个,因程序问题提交后变成了两个。

跟我学XSL(七)

 XSL函数一

 本期学习XSL样式方法,即可用于XSL元素< xsl:for-each >、< xsl:value-of >、< xsl:template >的select属性、< xsl:apply-templates >的match属性、< xsl:if >、< xsl:when >的test属性中,对元素的范围进行筛选,从而提供更大的灵活性。

  XML与DHTML(动态HTML)一样,这些节点都是一个个对象,而且这些对象都是有层次的,从根节点开始构成一颗层次清淅的树状结构,这就形成了文档对象模型DOM,通过对象的属性、方法来达到访问控制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) ?0岁的人的简历(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“]


八、comment()

含义:返回所有注释结点

示例:例如

resume[$$any$$ comment()=“禹希初的简历“]

表示寻找含有注释语句

< !--禹希初的简历-- >

的元素< resume >


九、cdata()

含义:返回所有CDATA类型的结点的集合

示例:例如

resume[$$any$$ cdata()=“禹希初的简历“]

表示寻找含有下述语句(必须是直接子结点)

< ![CDATA[禹希初的简历]] >

的元素< resume >


十、node()

含义:返回当前上下文环境中除根结点和属性结点以外的所有结点的集合,等价于

“* | pi() | comment() | text()”

示例:寻找所有元素resume,其最后一个结点的名字为“skill“

resume[node()[end()]!nodeName()=“skill“]

寻找所有resume元素的第一个结点:resume/node()[0]


十一、textnode()

含义:返回所有文本类型的结点的集合

示例:寻找每一个p元素的第二个文本结点

p/textnode(1)或p!textnode(1)

十二、text()

含义:返回所有表示文本字符串的结点的集合,等价于“cdata()|textnode()“;

  本期的内容就介绍至此,另有一个函数date()在本人的机器上一试就发生错误使浏览器自动关闭,还有一个函数pi()本人尚未找到适当的应用方法,就不介绍了,下期将讲述如何XSL中使用脚本。
good 5

发表评论

文明评论,重在参与

暂无评论!
用著作权法来保护软件是否真的有 07-28
杀毒软件:只在搞娱乐,从未杀过 07-28
小谈高通反垄断 07-28
印度将推出百元智能机 山寨厂商 07-28
高通垄断之痛:不是国产手机大而 07-28
一张图读懂阿里巴巴眼花缭乱资本 07-28
滴滴打车副总裁张晶离职 高层换 07-28
小米官网明日首发小米4 预约即 07-28
如何勾引马云马化腾花钱买你公司 07-28
云智慧成为2014 Web性能 07-28
顺丰试水微信扫码支付:发快递无 07-28
从Facebook看百度的移动 07-28
返回XML教程-返回首页
首页 社区 工具 关于 网址
切换:1.0/2.0-电脑-//
2009-2025 版权所有 wap123.cn