如何在不再次查询整个文档的情况下查询子元素的 xpath 结果?
我查询我的文档以找到<li>
该类的最后一个menu-item
:
$doc = new DomDocument();
@$doc->loadHTML( $html );
// $html is invalid (and should be at this point),
// so use @ sign to suppress errors
$xpath = new DomXPath( $doc );
$li = $xpath->query( "(//li[contains(concat(' ', normalize-space(@class), ' '), 'menu-item')])[last()]" )->item( 0 );
以上工作正常,现在我想查询$li
以找到以下内容:
$p = $xpath->query( "//p[contains(concat(' ', normalize-space(@class), ' '), 'field-description')]" )->item( 0 );
带有 class的p
标签field-description
。这不起作用并返回找到的第一个实例,如果我修改它并使用[last()]
(无论这是什么),那么它就可以工作,但它不一定是这里的最佳解决方案:
$p = $xpath->query( "(//p[contains(concat(' ', normalize-space(@class), ' '), 'field-description')])[last()]" )->item( 0 );
上面的行有效,但我想再次查询$li
而不是整个文档。