首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >normalize space(.)和normalize space(text())?

normalize space(.)和normalize space(text())?
EN

Stack Overflow用户
提问于 2011-05-13 20:57:57
回答 1查看 68.8K关注 0票数 26

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

代码语言:javascript
复制
"//td[starts-with(normalize-space()),'Posted Date:')]"

代码语言:javascript
复制
"//td[starts-with(normalize-space(text()),'Posted Date:')]"  

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

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2011-05-13 21:11:18

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

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

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

因此,例如,给定XML:

代码语言:javascript
复制
<a>Foo
    <b>Bar</b>
  lish
</a>

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

长话短说,如果您想规范化一个元素中的所有文本,请使用.。如果您想选择一个特定的文本节点,可以使用text(),但请始终记住,不管名称如何,text()都会返回一个节点集,只有当它只有一个元素时,它才会自动转换为一个字符串。

票数 58
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/5992177

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档