我正在尝试查找特定节点的所有直接子节点 A xor - 当且仅当存在 B 时作为 A 的孩子 - B 的直接子女。我很难过!
( A 和 B 代表特定元素;说<body/>
和<article/>
)
另一种方式:
如果某个元素 B 是 A 的孩子,请找到 B 的孩子,而不是 A 。否则,只需返回 A 的孩子。
或者,还有另一种方式:
A > c c c c c c...
A > B > c c c c c c...
无论 B 是否存在,我都希望得到[c, c, c, c, c, c, ...]
。如果所述级别出现在DOM中,我基本上想要“跳过一个级别”。请建议一种方法。
谢谢。
答案 0 :(得分:0)
//a[not(child::b)]/child::* | //b[parent::a]/child::*
答案 1 :(得分:0)
首先,两个与XPath 1.0兼容的示例:
你可以这样做:
(/parent/container/a[not(b)] | /parent/container/a/b)/*
或者使用双斜杠语法(除非路径非常长,否则我建议避免使用):
(//a[not(b)] | //a/b)/*
但是,由于您的问题是使用XPath 2.0标记的,因此以下内容可能比其中任何一个更有效:
/parent/container/a/(if (b) then b/* else *)
示例输入:
<parent>
<container>
<a>
<c>1</c>
<c>2</c>
</a>
</container>
<container>
<a>
<c>3</c>
<b>
<c>4</c>
<c>5</c>
</b>
<b>
<c>6</c>
</b>
<c>7</c>
</a>
</container>
<container>
<a>
<c>8</c>
</a>
</container>
</parent>
使用上述任何路径运行时,结果为:
<c>1</c>
<c>2</c>
<c>4</c>
<c>5</c>
<c>6</c>
<c>8</c>