elementHandle.$x(expression) 似乎没有相对于给定的 elementHandle 运行

Jeu*_*uke 3 javascript jestjs puppeteer

我有以下代码获取“总线”层的 elementHandle(在 32 个不同层的列表中)

const [layerFound] = await page.$x("//div[@class='layer']/label[.='Buses']/..");
Run Code Online (Sandbox Code Playgroud)

然后我需要对这个“层”对象中的其他元素进行一些激活/验证。但是下一行不是从 Buses 层抓取“visible-toggle”对象,而是从 32 列表的第一层抓取对象。

const [layerVis] = await layerFound.$x("//div[contains(@class, 'layer-option visible-toggle')]");
Run Code Online (Sandbox Code Playgroud)

我的理解是 elementHandle.$x(expression) 计算相对于 elementHandle 的 XPath 表达式。但它是相对于页面对象进行的。

其中有很多。第一个是“桥”。哪个是被发现/使用的。

<div class="layer">
  <label class="layer-label"><div>Buses</div></label>
  <div class="layer-option entity-count"><div>(629)</div></div>
  <div class="layer-option visible-toggle ">...</div>
  <div class="layer-option layer-preferences-toggle">...</div>
</div>
Run Code Online (Sandbox Code Playgroud)

Tur*_*ght 5

您需要使用相对 XPath:

const [layerVis] = await layerFound.$x(".//div[contains(@class, 'layer-option visible-toggle')]");
Run Code Online (Sandbox Code Playgroud)

(XPath 表达式前的点)

否则您的 XPath 将再次从文档根目录搜索。