Selenium WebDriver에서 JavaScript를 사용하여 XPath로 요소 가져오기
Selenium WebDriver/Java 내에서 JavaScript를 사용하여 요소의 innerHTML을 얻으려면(WebDriver는 찾을 수 없음) 여러 개가 있습니다
document.evaluate()를 사용한 XPath 평가
널리 채택되는 방법에는 document.evaluate() 함수를 사용하는 방법이 있습니다. XPath 표현식 문자열을 평가하여 가능한 경우 지정된 유형을 기반으로 결과를 반환합니다. 이를 활용하는 방법에 대한 예는 다음과 같습니다.
function getElementByXpath(path) { return document.evaluate(path, document, null, XPathResult.FIRST_ORDERED_NODE_TYPE, null).singleNodeValue; } console.log( getElementByXpath("//html[1]/body[1]/div[1]") );
이 예에서 XPath 표현식 "//html[1]/body[1]/div[1]"은 내의 첫 번째 div 요소를 검색합니다. 문서이며 innerHTML은 검색된 요소의 innerHTML 속성을 통해 얻습니다.
DOM을 사용한 사용자 정의 구현 순회
또 다른 옵션은 XPath 표현식을 기반으로 DOM(문서 개체 모델)을 순회하는 사용자 정의 함수를 만드는 것입니다. 이 접근 방식은 더 복잡한 XPath 표현식을 처리할 때 또는 document.evaluate()가 특정 요구 사항을 충족하지 않을 때 더 큰 유연성을 제공합니다. 기본 구현은 다음과 같습니다.
function getElementByXpathCustom(path) { // Implementation details for DOM traversal go here }
두 방법 모두 서로 다른 장점을 제공하며 특정 사용 사례에 따라 적합할 수 있습니다. document.evaluate()를 사용한 XPath 평가는 간단하며 많은 상황에서 충분할 수 있습니다. 사용자 정의 구현은 더 많은 제어 및 사용자 정의 옵션을 제공합니다.
ID 속성 고려 사항
ID 속성을 사용하는 것이 일반적인 접근 방식이지만 모든 요소에 ID 속성이 포함되는 것은 아니라는 점에 유의하는 것이 중요합니다. ID 속성. 이러한 경우 XPath 또는 사용자 정의 DOM 탐색 기능을 활용하면 DOM 내의 다른 속성이나 구조적 관계를 기반으로 요소를 검색할 수 있습니다.
위 내용은 Selenium WebDriver에서 JavaScript 및 XPath를 사용하여 요소 InnerHTML을 어떻게 얻을 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!