如何在使用 cssSelector 清除 Chrome 浏览器的浏览数据时定位 Shadow DOM (#shadow-root) 中的元素
与 Shadow 交互时Chrome 的“清除浏览数据”弹出窗口中的 DOM 元素,必须首先找到 #shadow-root 元素。使用 Selenium 的多次尝试都遇到了错误。
解决方案:
要克服这些错误,请按照以下 JavaScript 代码找到 #shadow-root element:
return document.querySelector('settings-ui').shadowRoot.querySelector('settings-main').shadowRoot.querySelector('settings-basic-page').shadowRoot.querySelector('settings-section > settings-privacy-page').shadowRoot.querySelector('settings-clear-browsing-data-dialog').shadowRoot.querySelector('#clearBrowsingDataDialog').querySelector('#clearBrowsingDataConfirm')
说明:
示例脚本:
driver.get("chrome://settings/clearBrowserData"); driver.manage().window().maximize(); JavascriptExecutor js = (JavascriptExecutor) driver; WebElement clearData = (WebElement) js.executeScript("return document.querySelector('settings-ui').shadowRoot.querySelector('settings-main').shadowRoot.querySelector('settings-basic-page').shadowRoot.querySelector('settings-section > settings-privacy-page').shadowRoot.querySelector('settings-clear-browsing-data-dialog').shadowRoot.querySelector('#clearBrowsingDataDialog').querySelector('#clearBrowsingDataConfirm')"); // perform the desired action on the clearData element clearData.click();
注意:
由于 Markdown 限制,答案源文本中提供的屏幕截图未包含在此回复中。
以上是如何使用 Selenium 与 Chrome 的'清除浏览数据”Shadow DOM 元素交互?的详细内容。更多信息请关注PHP中文网其他相关文章!