如何在使用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中文網其他相關文章!