以文本方式查看主题

-  中文XML论坛 - 专业的XML技术讨论区  (http://bbs.xml.org.cn/index.asp)
--  『 XSL/XSLT/XSL-FO/CSS 』  (http://bbs.xml.org.cn/list.asp?boardid=8)
----  XSL样式方法[推荐]  (http://bbs.xml.org.cn/dispbbs.asp?boardid=8&rootid=&id=7784)


--  作者:宇宙人
--  发布时间:5/21/2004 7:52:00 PM

--  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)小于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']


八、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()。


W 3 C h i n a ( since 2003 ) 旗 下 站 点
苏ICP备05006046号《全国人大常委会关于维护互联网安全的决定》《计算机信息网络国际联网安全保护管理办法》
6,156.250ms