>웹 프론트엔드 >JS 튜토리얼 >## 내 `addEventListener`가 Internet Explorer에서 작동하지 않는 이유는 무엇입니까?

## 내 `addEventListener`가 Internet Explorer에서 작동하지 않는 이유는 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-10-24 18:45:37345검색

##  Why Does My `addEventListener` Not Work in Internet Explorer?

MSIE AddEventListener 수수께끼: 이벤트 캡처 및 브라우저 간 호환성

웹 개발 영역에서는 이벤트 처리가 다음과 같은지 확인하는 것이 중요합니다. 다양한 브라우저에서 일관성을 유지합니다. 그러나 Internet Explorer(MSIE)에서 특정 이벤트를 수신하려고 하면 문제가 발생합니다.

이러한 문제 중 하나는 MSIE와 작업할 때 addEventListener가 호환되지 않는다는 것입니다. 복사 이벤트를 수신하려고 시도하는 제공한 코드 조각에 이 문제로 인해 오류가 발생했습니다.

문제의 근본 원인: AttachEvent를 Rescue에

다른 최신 브라우저와 달리 MSIE는 이벤트 수신을 위해 addEventListener 대신 attachmentEvent를 사용해야 합니다. 이러한 불일치를 수정하려면 다음과 같이 타사 스크립트를 보다 IE 친화적인 스크립트로 대체해야 합니다.

if (el.addEventListener) {
  el.addEventListener('copy', beforeCopy, false);
} else if (el.attachEvent) {
  el.attachEvent('oncopy', beforeCopy);
}

보너스 포인트: 세 번째 매개변수의 미스터리 풀기

addEventListener의 세 번째 매개변수인 useCapture는 이벤트를 캡처해야 하는지 아니면 DOM을 통해 버블링해야 하는지 결정합니다. false로 설정하면 이벤트가 가장 안쪽 요소에 먼저 전달된 다음 상위 요소로 전파되는 기본 동작인 버블링을 의미합니다.

추가 브라우저 간 호환성 팁

브라우저 간 호환성을 더욱 강화하려면 폴리필을 사용하여 addEventListener와 attachmentEvent 간의 미묘한 차이와 기타 브라우저별 단점을 추상화하는 것을 고려해 보세요. 주목할만한 폴리필은 다음과 같습니다:

  • [EventListener.js](https://developer.mozilla.org/en-US/docs/Web/API/EventTarget/addEventListener)
  • [ clouset.js](https://github.com/Clouset/Clouset)

이러한 브라우저별 고려 사항을 수용하고 필요한 브라우저 간 호환성 측정을 구현하면 웹 애플리케이션이 사용하는 브라우저에 관계없이 사용자 작업에 일관되게 응답합니다.

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

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