加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 资源网站 > 资源 > 正文

xpath – normalize-space(.)和normalize-space(text())之间有什

发布时间:2020-12-14 21:21:32 所属栏目:资源 来源:网络整理
导读:我正在写一个XPath表达式,我修复了一个奇怪的错误,但是下面两个XPath表达式有什么区别? "//td[starts-with(normalize-space()),'Posted Date:')]" 和 "//td[starts-with(normalize-space(text()),'Posted Date:')]" 主要是,第一个XPath表达式会捕获什么?因
我正在写一个XPath表达式,我修复了一个奇怪的错误,但是下面两个XPath表达式有什么区别?
"//td[starts-with(normalize-space()),'Posted Date:')]"

"//td[starts-with(normalize-space(text()),'Posted Date:')]"

主要是,第一个XPath表达式会捕获什么?因为我得到了很多奇怪的结果.那么text()在匹配中做了什么?另外,如果我说normalize-space()&正常化空间(.)?

解决方法

那么,真正的问题是:它们之间有什么区别.和文字()?

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

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

例如,给定XML:

<a>Foo
    <b>Bar</b>
  lish
</a>

并假设< a>是你的当前节点,normalize-space(.)将返回Foo Bar lish,但normalize-space(text())将失败,因为text()返回两个文本节点(Foo和lish)的节点集,这是规范化空间()不接受.

简而言之,如果要对元素中的所有文本进行规范化,请使用..如果要选择特定的文本节点,请使用text(),但始终记住,尽管名称如此,text()将返回nodeset,只有具有单个元素时才会自动转换为字符串.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读