如何使用 Puppeteer 检查 HTML 元素是否在视口(viewport)(可见区域)内可见?例如,如果我必须滚动才能看到一个按钮,那么它是不可见的。
page.waitForSelector('#element', { visible: true })
page.waitForSelector 函数不是我要找的,因为它只检查元素是否在 DOM 中并且没有被 CSS 属性隐藏。
有什么方法可以检查元素在视口(viewport)中的可见性吗?
最佳答案
您可以使用 elementHandle.isIntersectingViewport()
检查元素在当前视口(viewport)中是否可见:
const example = await page.$('#example');
if (await example.isIntersectingViewport()) {
// The element IS visible within the current viewport.
} else {
// The element IS NOT visible within the current viewport.
}
关于javascript - 检查视口(viewport)中的可见性( puppeteer 师),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48663356/