Shadow DOM 요소를 탐색하고 상호 작용하는 것은 웹 자동화에서 항상 어려운 과제였습니다. 이 기사에서는 이 프로세스를 단순화하는 Selenium 4에 도입된 최신 솔루션을 살펴봅니다.
Shadow DOM은 캡슐화된 DOM 트리를 생성하는 데 사용되는 웹 개발 기술입니다. 기본 문서 트리에서 숨겨져 있습니다. 이러한 요소는 성능 최적화 및 모듈화에 자주 사용됩니다. 그러나 그 모호함으로 인해 findElement와 같은 전통적인 Selenium 메소드를 사용하여 상호작용하는 것이 어려울 수 있습니다.
Selenium 4에는 WebElement라는 새로운 메소드가 도입되었습니다. Shadow DOM 요소와 직접 상호작용할 수 있는 getShadowRoot()입니다. 이 메소드는 Shadow DOM의 루트 요소를 반환하며, 이를 통해 내부의 하위 요소를 탐색하고 찾을 수 있습니다.
Shadow DOM 요소인 경우 다음 구문을 사용할 수 있습니다.
driver.findElement(By.id("parentId")).getShadowRoot().findElement(By.cssSelector("label")).findElement(By.tagName("input"));
이 예에서는 먼저 Shadow DOM의 상위 요소를 찾습니다. 그런 다음 getShadowRoot()를 사용하여 섀도우 루트에 액세스합니다. 여기에서 표준 Selenium 방법을 사용하여 Shadow DOM 내의 특정 하위 요소를 찾을 수 있습니다.
섀도우 루트는 제한되어 있습니다. 예를 들어 섀도우 루트 내에서 By.id() 또는 By.tagName()을 사용하면 InvalidArgumentException이 발생할 수 있습니다. By.cssSelector() 및 By.className()은 유효한 옵션으로 남아 있습니다.
위 내용은 Selenium 4는 Shadow DOM 요소 자동화를 어떻게 단순화합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!