>웹 프론트엔드 >JS 튜토리얼 >특히 Internet Explorer에서 브라우저 간 이벤트 리스너 호환성을 보장하려면 어떻게 해야 합니까?

특히 Internet Explorer에서 브라우저 간 이벤트 리스너 호환성을 보장하려면 어떻게 해야 합니까?

Susan Sarandon
Susan Sarandon원래의
2024-11-02 15:31:291096검색

How Can I Ensure Cross-Browser Event Listener Compatibility, Especially in Internet Explorer?

Internet Explorer의 addEventListener 호환성

addEventListener를 사용하여 이벤트 핸들러를 추가하는 것은 대부분의 브라우저에서 선호되는 DOM 방법입니다. 그러나 Internet Explorer(8버전까지는)에서는 attachmentEvent 메소드를 대신 사용하였다.

Internet Explorer 9 지원

Internet Explorer 9에서는 마침내 addEventListener 메소드를 채택하였고, 다른 최신 브라우저와 조화를 이룹니다. 이는 이제 IE9 이상에서 호환성 문제 없이 addEventListener를 사용할 수 있음을 의미합니다.

크로스 브라우저 호환성

이전 버전과 최신 버전을 모두 지원하려는 경우 Internet Explorer는 물론 다른 브라우저에서도 다음과 같은 크로스 브라우저 addEvent 함수를 사용할 수 있습니다.

function addEvent(evnt, elem, func) {
   if (elem.addEventListener)  // W3C DOM
      elem.addEventListener(evnt,func,false);
   else if (elem.attachEvent) { // IE DOM
      elem.attachEvent("on"+evnt, func);
   }
   else { // No much to do
      elem["on"+evnt] = func;
   }
}

이 함수는 요소가 addEventListener를 지원하는지 확인하고, 그렇지 않은 경우 IE 호환성을 위해 attachmentEvent를 사용합니다. 그렇지 않으면 이벤트 핸들러를 직접 설정하는 것으로 대체됩니다.

위 내용은 특히 Internet Explorer에서 브라우저 간 이벤트 리스너 호환성을 보장하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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