normalize-space(.)和normalize-space(text())之间有什么区别?

Kar*_*rim 22 xpath

我正在写一个XPath表达式,我有一个奇怪的错误,我修复了,但以下两个XPath表达式之间有什么区别?

"//td[starts-with(normalize-space()),'Posted Date:')]"
Run Code Online (Sandbox Code Playgroud)

"//td[starts-with(normalize-space(text()),'Posted Date:')]"  
Run Code Online (Sandbox Code Playgroud)

主要是,第一个XPath表达式会捕获什么?因为我得到了很多奇怪的结果.那么text()匹配中的制作是什么?另外,如果我说normalize-space()&是否有区别normalize-space(.)

biz*_*lop 43

那么,真正的问题是:.和之间的区别是什么text()

.是当前节点.如果您在需要字符串的地方使用它(即作为参数normalize-space()),引擎会自动将节点转换为节点的字符串值,对于元素,元素是连接元素中的所有文本节点.(因为我猜这个问题实际上是关于元素的.)

text() 另一方面,仅选择作为当前节点的直接子节点的文本节点.

例如,给定XML:

<a>Foo
    <b>Bar</b>
  lish
</a>
Run Code Online (Sandbox Code Playgroud)

假设<a>是您当前的节点,normalize-space(.)将返回Foo Bar lish,但normalize-space(text())将失败,因为text()返回两个文本节点(Foolish)的节点集,它们normalize-space()不接受.

简而言之,如果要标准化元素中的所有文本,请使用..如果要选择特定的文本节点,请使用text(),但始终记住,尽管名称如此,但text()返回一个节点集,如果它只有一个元素,则只会自动转换为字符串.

  • 试试text()[normalize-space()] (4认同)