XSLT分析之一:XPath表达式

正在<看XSLT开发人员指南>,对里面的内容进行总结归纳
Xpath
XSLT(Extensible Stylesheet Language for Transformations,可扩展样式表语言)用到的表达式语法,用于定位XSLT文档中元素的位置。

Xpath定位寻址有两种语法:一种未经缩写的语法和一种缩写的语法。未经缩写的语法可以很清晰的表达出定位路径的含义,对于开始阶段学习理解一些概念非常有帮助。大多数开发人员都使用缩写的语法,这样开发效率更高。

一个定位步骤包含3个部分:轴(axis)、节点测试和谓词(predicate).轴和节点测试通过一个双冒号(::)来分开,他们都是必须的。而谓词可选的,如果指定了谓词,那么它就必须紧接着节点测试,并且由中括号([])括起来。定位路径中的每一个定位步骤都是由一个斜杠(/)分开的。如果节点的查找开始于根节点(绝对路径),第一个定位步骤也开始于一个斜杠。

下面写出一些常用的Xpath语法:

1.       含义:选择文档的根

未缩写的语法:/

缩写的语法:/

2.       含义:选择当前节点的子节点中的所有para元素节点

未缩写的语法:child::para

缩写的语法:    para

3.       含义:选择根节点中的子节点的所有para元素节点(注意与上一个例子的区别)

未缩写的语法:/child::para

缩写的语法:    /para

4.       含义:选择当前节点的后代节点中的所有para元素节点

未缩写的语法:descendant::para

缩写的语法:    .//para

5.       含义:选择根节点的后代节点中所有para元素节点(注意与上一个例子的区别)

未缩写的语法:/descendant::para

缩写的语法:    //para

6.       含义:选择当前节点的所有id属性

未缩写的语法:attribute::id

缩写的语法:    @para

7.       含义:选择当前节点的所有属性

未缩写的语法:attribute::*

缩写的语法:    @*

8.       含义:选择当前节点的子节点中的第五个chapter元素节点

未缩写的语法:child::chapter[position()=5]

缩写的语法:    chapter[5]

9.       含义:选择当前节点的子节点中id值为this-one的所有chapter元素节点

未缩写的语法:child::chapter[attribute::id=”this-one”]

缩写的语法:    chapter[@id=”this-one”]

10.   含义:选择属性值不为y的所有chapter元素节点

未缩写的语法:child::chapter[not(attribute::include=”y”)]

缩写的语法:    chapter[@include =”y”]

11.   含义:选择根节点中的后代中的所有文本节点(也就是文档中所有的文本节点)

未缩写的语法:/descendant::text()

缩写的语法:    //text()

12.   含义:选择当前节点的子节点中的num属性值为1draft属性值为y的所有part节点

未缩写的语法:child::part[attribute::num=”1”] [attribute::draft=”y”]

缩写的语法:    chapter[@num =”1”] [@draft =”y”]

13.   含义:选择当前节点的父节点,如果该父节点由include属性且值为y

未缩写的语法:parent::node()[attribute::include=”y”]

缩写的语法:    .. [@include =”y”]

14.   含义:选择同时具有id属性和include属性的所有chapter元素节点(不管属性值是什么)

未缩写的语法:/descendant::chapter[attribute::id and attribute::include]

缩写的语法:    //chapter[@id and @include]

posted on 2006-04-12 21:25  Shanks  阅读(1470)  评论(0编辑  收藏  举报

导航