>Java >java지도 시간 >Selenium을 사용하여 Chrome에서 중첩된 Shadow DOM 요소에 액세스하는 방법은 무엇입니까?

Selenium을 사용하여 Chrome에서 중첩된 Shadow DOM 요소에 액세스하는 방법은 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2024-12-30 02:29:18205검색

How to Access Nested Shadow DOM Elements in Chrome Using Selenium?

Shadow DOM 요소 액세스: Chrome에서 검색 데이터를 삭제하는 동안 #shadow-root(열기)와 상호 작용

#shadow-root와 인터페이스 Chrome의 인터넷 사용 기록 삭제 팝업에 있는 '데이터 삭제' 버튼과 같은 요소는 다음과 같은 이유로 Selenium 내에서 특별한 처리가 필요합니다. Shadow DOM 내의 캡슐화.

문제 설명:

Selenium을 사용하여 Chrome의 검색 데이터 지우기 팝업을 자동화하는 동안 " cssSelector를 사용하여 데이터 지우기" 버튼을 누르면 예외.

해결책:

이러한 맥락에서 Shadow DOM의 중첩 특성으로 인해 대상 요소에 액세스하려면 여러 섀도우 루트 수준을 통과해야 합니다. 사용자 정의 메소드인 getShadowElement를 사용하면 섀도우 트리 요소에 대한 간소화된 액세스가 가능합니다.

public static WebElement getShadowElement(WebDriver driver, WebElement shadowHost, String cssOfShadowElement) {
    WebElement shardowRoot = getShadowRoot(driver, shadowHost);
    return shardowRoot.findElement(By.cssSelector(cssOfShadowElement));
}

여러 getShadowElement 호출을 연결하여 섀도우 DOM 수준을 점진적으로 내려갈 수 있습니다.

// Locate shadowHost on the current dom
WebElement shadowHostL1 = driver.findElement(By.cssSelector("settings-ui"));

// now locate the shadowElement by traversing all shadow levels
WebElement shadowElementL1 = getShadowElement(driver, shadowHostL1, "settings-main");
WebElement shadowElementL2 = getShadowElement(driver, shadowElementL1,"settings-basic-page");
WebElement shadowElementL3 = getShadowElement(driver, shadowElementL2,"settings-section > settings-privacy-page");
WebElement shadowElementL4 = getShadowElement(driver, shadowElementL3,"settings-clear-browsing-data-dialog");
WebElement shadowElementL5 = getShadowElement(driver, shadowElementL4,"#clearBrowsingDataDialog");
WebElement clearData = shadowElementL5.findElement(By.cssSelector("#clearBrowsingDataConfirm"));

또는 , 단일 JavaScript 호출로 순회를 캡슐화할 수 있습니다. process:

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')");

이 접근 방식을 사용하면 중첩된 Shadow DOM 구조에 관계없이 "데이터 지우기" 버튼을 포함하여 #shadow-root(열기) 요소와 원활한 상호 작용이 가능합니다.

위 내용은 Selenium을 사용하여 Chrome에서 중첩된 Shadow DOM 요소에 액세스하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.