MSIE의 \'copy\' 이벤트에 대해 `addEventListener`가 작동하지 않는 이유는 무엇입니까?

Barbara Streisand
풀어 주다: 2024-10-25 07:17:02
원래의
186명이 탐색했습니다.

Why Doesn't `addEventListener` Work for the 'copy' Event in MSIE?

MSIE에서 addEventListener 문제 해결

Javascript에서 addEventListener를 사용하여 '복사' 이벤트를 구현하려고 하면 다음 오류가 발생할 수 있습니다. MSIE:

<code class="javascript">document.getElementById('container').addEventListener('copy',beforecopy,false );
Object doesn't support this property or method</code>
로그인 후 복사

솔루션

MSIE는 표준 addEventListener 접근 방식과 다르며 대신 'attachEvent'를 사용해야 합니다. 이는 조건부 검사를 통해 달성할 수 있습니다:

<code class="javascript">if (el.addEventListener){
  el.addEventListener('click', modifyText, false); 
} else if (el.attachEvent){
  el.attachEvent('onclick', modifyText);
}</code>
로그인 후 복사

또는 이 프로세스를 추상화하기 위해 사용자 정의 함수를 생성할 수 있습니다:

<code class="javascript">function bindEvent(el, eventName, eventHandler) {
  if (el.addEventListener){
    el.addEventListener(eventName, eventHandler, false); 
  } else if (el.attachEvent){
    el.attachEvent('on'+eventName, eventHandler);
  }
}
//...
bindEvent(document.getElementById('myElement'), 'click', function () {
  alert('element clicked');
});</code>
로그인 후 복사

보너스: 세 번째 매개변수(useCapture)

addEventListener('useCapture')의 세 번째 인수는 이벤트 처리 우선 순위를 결정합니다. true로 설정되면 이벤트 캡처가 필요함을 나타내며 이벤트는 대상 요소에 도달하기 전에 요소의 조상에서 처리됩니다.

위 내용은 MSIE의 \'copy\' 이벤트에 대해 `addEventListener`가 작동하지 않는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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