XPath中ancestor轴选取所有上级祖先节点(不含自身),descendant轴选取所有下级后代节点(不含自身);二者均为路径方向关键词而非函数,配合谓词可精准定位,且存在包含自身的ancestor-or-self和descendant-or-self变体。

XPath 中选取祖先节点和后代节点,主要靠 ancestor 和 descendant 这两个轴(axis),它们不是函数,而是用于定位相对关系的路径方向关键词。
ancestor 轴从当前节点出发,向上匹配所有父级、祖父级……直到根节点的元素(不包括自身)。
//div[@id="content"]/ancestor::section —— 找 id 为 content 的 div 的所有 section 类型祖先ancestor::* 匹配所有祖先元素(任意标签);ancestor::body 只匹配 body 祖先ancestor 不包含当前节点,也不包含父节点(parent)以外的“直接”限制——它就是全部向上穿透descendant 轴从当前节点出发,向下匹配所有子孙节点(子、孙、曾孙……任意深度,不包括自身)。
//ul/descendant::li —— 找 ul 下所有层级的 li 元素(比 //ul//li 更明确表达“后代”语义)descendant::* 匹配所有后代元素;descendant::span 只找 span 后代//:虽然 //ul//li 效果常等价于 //ul/descendant::li,但后者语义更清晰,也支持更精确的限定(比如加位置或条件)如果想包含当前节点本身,就用带 -or-self 的版本:
ancestor-or-self::div → 当前节点如果是 div,也会被选中;否则只选 div 类型的祖先descendant-or-self::p → 当前节点如果是 p,加上它所有的 p 后代//p 实际等价于 /descendant-or-self::*/p(在文档根开始查)这些轴通常配合谓词(方括号)使用,才能真正精准定位:
//div[@id="main"]/ancestor::*[@class="wrapper"][1]
//table/descendant::tr[2]/td 或更稳一点://table/tr/td(用层级比 descendant 更可控)../.. 或 div/div/p)高效,优先考虑可读性和稳定性基本上就这些。记住 axis 是“方向”,不是函数,后面跟双冒号再写节点名,搭配谓词就能灵活控制范围。
以上就是XPath怎么选取祖先节点和后代节点 ancestor和descendant的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号