XPath:如果存在子节点,则查询节点的 children XOR 子节点的 children
XPath: Query a node's children XOR a subnode's children if subnode is present
我正在尝试查找特定节点的所有直接 children A xor -- 如果并且仅当 B 作为 A 的 child 存在时 - [=31= 的直接 children ]B。我被难住了!
(A和B表示具体元素;比如<body/>
和<article/>
)
另一种方式:
如果某个元素B是A的child,求children的B 而不是 A。否则,只是return A的children。
或者,还有另一种方式:
A > c c c c c c...
A > B > c c c c c c...
无论是否存在B,我都想得到[c, c, c, c, c, c, ...]
。如果所述级别出现在 DOM 中,我基本上想要 "skip a level"。请推荐一个方法。
谢谢。
//a[not(child::b)]/child::* | //b[parent::a]/child::*
首先,两个兼容 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>
我正在尝试查找特定节点的所有直接 children A xor -- 如果并且仅当 B 作为 A 的 child 存在时 - [=31= 的直接 children ]B。我被难住了!
(A和B表示具体元素;比如<body/>
和<article/>
)
另一种方式:
如果某个元素B是A的child,求children的B 而不是 A。否则,只是return A的children。
或者,还有另一种方式:
A > c c c c c c...
A > B > c c c c c c...
无论是否存在B,我都想得到[c, c, c, c, c, c, ...]
。如果所述级别出现在 DOM 中,我基本上想要 "skip a level"。请推荐一个方法。
谢谢。
//a[not(child::b)]/child::* | //b[parent::a]/child::*
首先,两个兼容 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>