>Java >java지도 시간 >Selenium 및 CSS 선택기를 사용하여 Chrome의 Shadow DOM 내부 요소와 상호 작용하는 방법은 무엇입니까?

Selenium 및 CSS 선택기를 사용하여 Chrome의 Shadow DOM 내부 요소와 상호 작용하는 방법은 무엇입니까?

DDD
DDD원래의
2024-12-20 08:30:09917검색

How to Interact with Elements Inside a Chrome's Shadow DOM Using Selenium and CSS Selectors?

CSS 선택기와 함께 Selenium을 사용하여 Chrome 브라우저의 검색 데이터를 삭제하는 동안 #shadow-root(open) 내의 요소와 상호작용하는 방법은 무엇입니까?

문제:

상호작용을 자동화하려고 할 때 Selenium을 사용하여 검색 데이터 지우기 팝업의 #shadow-root(열기) 내의 요소를 사용하면 데이터 지우기 버튼을 찾는 데 어려움을 겪을 수 있습니다. 요소를 식별하기 위해 CSS 선택기를 사용하는 경우 이는 특히 실망스러울 수 있습니다.

해결책:

#shadow-root 내의 요소를 성공적으로 찾고 상호 작용하려면 (open) Selenium을 사용하려면 JavaScript 실행과 Shadow DOM에 대한 이해를 함께 사용해야 합니다. 자세한 단계별 접근 방식은 다음과 같습니다.

1. 섀도우 루트 가져오기:

private static WebElement getShadowRoot(WebDriver driver, WebElement shadowHost) {
    JavascriptExecutor js = (JavascriptExecutor) driver;
    return (WebElement) js.executeScript("return arguments[0].shadowRoot", shadowHost);
}

이 메소드는 ShadowHost 요소를 인수로 사용하고 해당 섀도우 루트를 반환합니다.

2. 그림자 요소에 액세스:

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

이 메소드는 ShadowHost 요소와 그림자 요소에 대한 CSS 선택기를 사용하고 섀도우 루트 내의 해당 그림자 요소를 반환합니다.

3. Shadow 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");
// and so on...

4. JavaScript 실행:

대체 접근 방식은 JavaScript 실행을 사용하여 요소를 직접 선택하는 것입니다. 이는 여러 그림자 수준을 통과하는 것이 복잡하거나 비현실적인 경우 유용할 수 있습니다. 예는 다음과 같습니다.

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

이 코드는 JavaScript 실행을 사용하여 Clear 데이터 요소를 검색하여 순회 프로세스를 크게 단순화합니다.

이러한 단계를 따르면 Selenium의 CSS 선택기 접근 방식을 사용하여 Chrome 브라우저에서 인터넷 사용 기록을 삭제하는 동안 #shadow-root(열기).

위 내용은 Selenium 및 CSS 선택기를 사용하여 Chrome의 Shadow DOM 내부 요소와 상호 작용하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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