XPath是一种用来从文档树中选择节点和节点集的语言。从XPath的角度来看,共有七种节点:
CDATA部份,实体引用和文档类型声明不包括在内,XPath在所有这些项都并入文档之后才起作用。根节点和根元素是不同的两个概念,根节点包含整篇文档,包括根元素。 本文由建站学(http://www.jzxue.com)转载发布!转载请注明出处,谢谢! 1. 匹配模式匹配模板的通用模式 Table 6.1.
2. XPath轴XPath提供了选择节点的机制,两个较有用的是轴选择和谓语选择,轴指定上下文节点和要选择的节点的关系。共有十三种轴,最常用的有四种,分别是子轴(child)、属性轴(attribute)、自已(self)、双亲(parent)。 Table 6.2. XPath轴描述
3. 谓词XPath表达式可以匹配多个节点,如需对匹配的节点进行进一步的筛选,可以使用谓词。 Table 6.3. 选择节点常用谓词
home/person/@id这种定位路径的写法叫简写定位路径,该写法简洁,容易理解,是XSLT匹配模式中最常用的写法。还有一种称为非简写定位路径的写法,它把节点测试和轴结合在一起,如child::home/child::person/attribute::id。该写法在实际使用中不常用,但它具有非常重要的性能因此有必要了解。 4. XPath表达式位置路径是XPath的一个最常用的表达式,用以标识XML文档的节点集。除此之上,XPath表达式还可返回数字、布尔和字符串。非节点集的XPath表达式不能用于xsl:template元素的match属性中。它们用于xsl:value-of元素的select属性值或用于位置路径的谓词中。 每个XPath位置路径可分为一步名多步,每步以“/”号分隔,如: room[\@name=$root]/date[year=$year and month=$month]/meeting 上下文节点即当前正在处理的节点,也就是位置路径定位的当前节点。上下文在XPath表达式计算前被创建,由XSLT处理器创建。处理每一步后,上下文都会改变。 位置路径中的步可分为三部份:轴(axis)、节点测试(note test)和谓词(predicate),它的写法如下: axis::note-test[predicate] 轴和节点测试之间用“::”分开,每个谓词由括号[]括起来。 要设计好一个位置路径,需确保在每一步选择最少的节点,使用最严格的轴,用最严格的节点测试。避免使用谓词,因为由轴和节点测试选择的节点集的每个节点都会用作谓词的上下文节点。对于位置路径的三步,最节省的是节点测试。 XPath中的所有数字都是8个字节的IEEE754浮点双精度类型,与java的double类型相同。可表示正无穷大、负无穷大和NaN(零除零)值。支持五种运算符,分别是加(+)、减(-)、乘(*)、除(div)、取余(mod)。 XPath中的字符串是Unicode字符,用单引号或双引号定界。可以使用=和!=对字符进行比较,也可用<,>,<=,>关系运算符,但比较的两个字符必须是数字,否则比较结果没有意义。 XPath中的布尔值常用于位置路径的谓词中,如/person[name="debian"]。布尔值还常用于xsl:if和xsl:when元素的test属性中。如: <xsl:template match="home"> <xsl:if test = ".='debian' or .='redhat'"> <xsl:value-of select = "." /> </xsl:if> </xsl:template> 5. XPath函数XPath还提供很多函数,用于表达式和谓词。XPath函数的返回值有四种类型,分别是:
|