位置路径
位置路径是一种 XPath 表达式,用于选择相对于上下文节点的一组节点。计算位置路径表达式所得到的节点集,将包含位置路径指定的节点。位置路径可以以递归方式包含表达式,用来筛选节点集。
在语法上,位置路径由一个或多个定位步骤组成,每个步骤通过正斜杠 (/) 分隔:
locationstep/locationstep/locationstep
每个定位步骤依次选择相对于上下文节点(即上一个定位步骤所选择的节点)的一组节点。通过这种方式表示的位置路径为相对位置路径。绝对位置路径从根元素开始:
/locationstep/locationstep/locationstep
在位置路径中,定位步骤从左到右进行计算。最左侧的定位步骤选择一组相对于上下文节点的节点。然后,这些节点成为上下文节点,用于处理下一个定位步骤。这种步骤的处理和上下文节点的更新自行重复,直到所有定位步骤处理完毕。
位置路径可以缩写,也可以不缩写。
在不缩写的位置路径中,定位步骤采用以下语法:
axis::node-test[predicate]
在此语法中,axis 指定定位步骤选择的节点与上下文节点的关系;node-test 指定定位步骤选择的节点的节点类型和扩展名称;predicate 是一个筛选表达式,进一步精确定位步骤中的节点选择。谓词是可选的。在此例中,定位步骤仅包含 axis:: 和 node-test。下表提供了一些示例。
不缩写的位置路径 |
说明 |
---|---|
child::para[last()] |
选择上下文节点的最后一个 <para> 元素。 |
parent::para |
选择属于上下文节点父级的 <para> 元素。 |
child::text() |
选择上下文节点的所有文本节点子级。 |
child::div/child::para |
选择属于上下文节点子级的 <div> 元素的 <para> 子元素。 |
在缩写的位置路径中,轴指定符 axis:: 在定位步骤中未明确表达,而是通过一组快捷方式暗示。下表提供了一些示例。
缩写的位置路径 |
说明 |
---|---|
para |
选择上下文节点的 <para> 元素。 |
../para |
选择属于上下文节点父级的 <para> 元素。 |
text() |
选择上下文节点的所有文本节点子级。 |
./div/para |
选择上下文节点的 <div> 元素子级的 <para> 元素子级。 |
下面总结了一些缩写:
不缩写 |
缩写 |
---|---|
child::* |
* |
attribute::* |
@* |
/descendant-or-self::node() |
// |
self::node() |
. |
parent::node() |
.. |
本节内容
下列主题详细讨论位置路径各个部分的语法和用法。