XPath中选择注释节点使用comment()节点测试,它匹配XML/HTML中的注释;comment()是节点类型测试而非函数,不接受参数,可用谓词过滤如comment()[contains(.,'TODO')],注意HTML解析器常丢弃注释需用支持工具验证。

XPath 中选择注释节点用 comment() 节点测试(node test),它匹配 XML 或 HTML 文档中的注释节点(即 <!-- ... --> 部分)。
直接写 comment() 就表示“当前上下文下的注释节点”。例如:
//comment() —— 选取文档中所有注释节点/html/body/comment() —— 选取 body 元素直接子节点中的注释(注意:注释是节点,可能出现在元素之间)comment()[1] —— 选取当前上下文中的第一个注释节点comment()[contains(., 'TODO')] —— 选取内容包含 "TODO" 的注释(. 表示注释文本内容)comment() 看起来像函数,但其实是 XPath 的“节点测试”,和 text()、node()、* 同类。它不接受参数(除了可选的谓词 [...]),也不能写成 comment('xxx') —— 那样会报错。
//comment() 在某些环境下返回空 —— 建议用原始 XML 字符串或支持注释的解析器(如 lxml、Saxon)测试name(comment()) 获取名称;它的节点类型是 comment,可通过 node-name()(XPath 2.0+)或 local-name() 辅助判断string(comment()) 或直接 comment()/text()(不过注释节点本身没有子 text 节点,推荐用 string() 包裹)基本上就这些。用对 comment() 就能精准定位那些藏在代码里的说明性注释了。
以上就是XPath怎么选择注释节点 comment()的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号