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 간의 미묘한 차이와 기타 브라우저별 단점을 추상화하는 것을 고려해 보세요. 주목할만한 폴리필은 다음과 같습니다:
이러한 브라우저별 고려 사항을 수용하고 필요한 브라우저 간 호환성 측정을 구현하면 웹 애플리케이션이 사용하는 브라우저에 관계없이 사용자 작업에 일관되게 응답합니다.
위 내용은 ## 내 `addEventListener`가 Internet Explorer에서 작동하지 않는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!