> 웹 프론트엔드 > JS 튜토리얼 > PhantomJS에서 클릭 이벤트를 올바르게 시뮬레이션하는 방법은 무엇입니까?

PhantomJS에서 클릭 이벤트를 올바르게 시뮬레이션하는 방법은 무엇입니까?

DDD
풀어 주다: 2024-12-09 12:45:14
원래의
425명이 탐색했습니다.

How to Properly Simulate Click Events in PhantomJS?

PhantomJS에서 요소 클릭

page.evaluate 함수와 document.getElementById('idButtonSpan').click()을 사용하여 PhantomJS에서 요소를 클릭하려고 할 때; , 요소가 존재하더라도 "정의되지 않은 것은 함수가 아닙니다..."라는 오류가 발생할 수 있습니다. 이는 .click()이 PhantomJS에서 요소를 클릭하는 표준 함수가 아니기 때문입니다.

PhantomJS에서 클릭 이벤트를 시뮬레이션하려면 다음과 같이 사용자 정의 이벤트를 생성하고 전달해야 합니다.

function click(el) {
    var ev = document.createEvent("MouseEvent");
    ev.initMouseEvent(
        "click",
        true, // bubble
        true, // cancelable
        window,
        null,
        0, // screenX
        0, // screenY
        0, // clientX
        0, // clientY
        false, // ctrlKey
        false, // altKey
        false, // shiftKey
        false, // metaKey
        0, // button
        null // relatedTarget
    );
    el.dispatchEvent(ev);
}
로그인 후 복사

그런 다음 원하는 요소에 이 클릭 기능을 사용하여 클릭 이벤트를 시뮬레이션할 수 있습니다.

위 내용은 PhantomJS에서 클릭 이벤트를 올바르게 시뮬레이션하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿