我怎样才能访问任何 <ul>,然后访问其使用的 puppeteer 的任何 <li> 项目?
how can I access any <ul> and then any <li> item of its using puppeteer?
例如:给定一个页面中的设施部分,它包含以列方式在不同 ul 中可用的不同设施。(所以像第 1 列的 ul 包含列表项(li)形式的各种设施)。
所以我只想访问第二个 ul(想象 table 的第二列)及其第 4 和第 5 个列表项(li)。
如果我这样做,document.querySelector(".text-body li") 那么我将只从第一个 ul 获取数据,但我想从第二个 ul 获取数据。
这里的 .text-body 是 class 并且每个列表都相同。
<div class="text-block hospital-facility" id="section-facilities">
<h2 class="text-block-title"></h2>
<div class="facility-list"›
<h4 class="text-block-list-title">Comfort During Stay</h4>
<div class="text-body add-view-more" data-visible-item="6" data-
showmore-text="More Details">
<ul>...</ul>
<p class="text-right vm-wrp"></p> </div> </div>
<div class="facility-list>
<h4 class="text-block-list-title">Money Matters</h4>
<div class="text-body">
<u1>
<li>Health insurance coordination</li>
<li>Medical travel insurance</li>
<li>Foreign currency exchange</li>
<li>ATM</li> <li>Credit Card< li>
</ul>
上面代码中,第二个ul包含各种支付方式,我都需要。
我们可以做 ul:last-child 但是大约有 6-7 个 ul 标签所以我们需要一些东西 select 只有第二个 ul
所以我想你的 html 看起来像这样:
<div id="ulParent">
<ul>
<li>li11</li>
<li>li12</li>
</ul>
<ul>
<li>li21</li>
<li>li22</li>
</ul>
</div>
那么你可以这样做:
var secondUl = document.querySelector("#ulParent ul:nth-child(2)");
var fourthLi = secondUl.querySelector("li:nth-child(4)");
var fifthLi = secondUl.querySelector("li:nth-child(5)");
OP添加后更新HTML示例:
因此 HTML
:
<div class="text-block hospital-facility" id="section-facilities">
<h2 class="text-block-title"></h2>
<div class="facility-list">
<h4 class="text-block-list-title">Comfort During Stay</h4>
<div class="text-body add-view-more" data-visible-item="6" data-showmore-text="More Details">
<ul><li>...</li></ul>
<p class="text-right vm-wrp"></p>
</div>
</div>
<div class="facility-list">
<h4 class="text-block-list-title">Money Matters</h4>
<div class="text-body">
<ul>
<li>Health insurance coordination</li>
<li>Medical travel insurance</li>
<li>Foreign currency exchange</li>
<li>ATM</li>
<li>Credit Card</li>
</ul>
</div>
</div>
</div>
ul
不是其父项的第二个子项,因此您不能使用 :nth-child(2)
。
相反,您需要第一个 ul
第二个 .facility-list
:
var targetUl = document.querySelector("#section-facilities .facility-list:nth-of-type(2) ul");
// then retrieve the `li`s as the previous example shows:
var fourthLi = targetUl.querySelector("li:nth-child(4)");
var fifthLi = targetUl.querySelector("li:nth-child(5)");
请注意,您还可以使用 xpath 获取 targetUl
:
var targetUl = $x("//h4[contains(text(), 'Money Matters')]//following-sibling::div//ul");
例如:给定一个页面中的设施部分,它包含以列方式在不同 ul 中可用的不同设施。(所以像第 1 列的 ul 包含列表项(li)形式的各种设施)。 所以我只想访问第二个 ul(想象 table 的第二列)及其第 4 和第 5 个列表项(li)。
如果我这样做,document.querySelector(".text-body li") 那么我将只从第一个 ul 获取数据,但我想从第二个 ul 获取数据。
这里的 .text-body 是 class 并且每个列表都相同。
<div class="text-block hospital-facility" id="section-facilities">
<h2 class="text-block-title"></h2>
<div class="facility-list"›
<h4 class="text-block-list-title">Comfort During Stay</h4>
<div class="text-body add-view-more" data-visible-item="6" data-
showmore-text="More Details">
<ul>...</ul>
<p class="text-right vm-wrp"></p> </div> </div>
<div class="facility-list>
<h4 class="text-block-list-title">Money Matters</h4>
<div class="text-body">
<u1>
<li>Health insurance coordination</li>
<li>Medical travel insurance</li>
<li>Foreign currency exchange</li>
<li>ATM</li> <li>Credit Card< li>
</ul>
上面代码中,第二个ul包含各种支付方式,我都需要。 我们可以做 ul:last-child 但是大约有 6-7 个 ul 标签所以我们需要一些东西 select 只有第二个 ul
所以我想你的 html 看起来像这样:
<div id="ulParent">
<ul>
<li>li11</li>
<li>li12</li>
</ul>
<ul>
<li>li21</li>
<li>li22</li>
</ul>
</div>
那么你可以这样做:
var secondUl = document.querySelector("#ulParent ul:nth-child(2)");
var fourthLi = secondUl.querySelector("li:nth-child(4)");
var fifthLi = secondUl.querySelector("li:nth-child(5)");
OP添加后更新HTML示例:
因此 HTML
:
<div class="text-block hospital-facility" id="section-facilities">
<h2 class="text-block-title"></h2>
<div class="facility-list">
<h4 class="text-block-list-title">Comfort During Stay</h4>
<div class="text-body add-view-more" data-visible-item="6" data-showmore-text="More Details">
<ul><li>...</li></ul>
<p class="text-right vm-wrp"></p>
</div>
</div>
<div class="facility-list">
<h4 class="text-block-list-title">Money Matters</h4>
<div class="text-body">
<ul>
<li>Health insurance coordination</li>
<li>Medical travel insurance</li>
<li>Foreign currency exchange</li>
<li>ATM</li>
<li>Credit Card</li>
</ul>
</div>
</div>
</div>
ul
不是其父项的第二个子项,因此您不能使用 :nth-child(2)
。
相反,您需要第一个 ul
第二个 .facility-list
:
var targetUl = document.querySelector("#section-facilities .facility-list:nth-of-type(2) ul");
// then retrieve the `li`s as the previous example shows:
var fourthLi = targetUl.querySelector("li:nth-child(4)");
var fifthLi = targetUl.querySelector("li:nth-child(5)");
请注意,您还可以使用 xpath 获取 targetUl
:
var targetUl = $x("//h4[contains(text(), 'Money Matters')]//following-sibling::div//ul");