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

내 RemoveEventListener가 JavaScript에서 작동하지 않는 이유는 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2024-11-03 08:08:30469검색

Why Is My removeEventListener Not Working in JavaScript?

Javascript RemoveEventListener가 작동하지 않음

이벤트 처리 영역에서 RemoveEventListener 메소드는 이벤트 리스너를 요소에서 분리하는 데 중요한 역할을 합니다. 그러나 RemoveEventListener가 예상대로 작동하지 않는 문제가 발생하면 실망스러울 수 있습니다.

다음 코드 조각을 고려하세요.

<code class="javascript">area.addEventListener('click',function(event) {
    app.addSpot(event.clientX,event.clientY);
    app.addFlag = 1;
},true);</code>

이 코드는 'click'에 대한 이벤트 리스너로 익명 함수를 능숙하게 연결합니다. 'area' 요소에 대한 ' 이벤트입니다. 그러나 다음 코드를 사용하여 이 리스너를 제거하려고 하면

<code class="javascript">area.removeEventListener('click',function(event) {
    app.addSpot(event.clientX,event.clientY);
    app.addFlag = 1;
},true);</code>

장애물이 발생할 수 있습니다. 문제는 addEventListener 및 RemoveEventListener에 사용되는 익명 함수의 고유한 특성에 있습니다. RemoveEventListener의 인수로 제공되는 함수가 이전에 등록한 함수와 동일하지 않습니다. 이 문제를 해결하려면 명명된 변수에 리스너 함수를 할당하십시오.

<code class="javascript">function foo(event) {
    app.addSpot(event.clientX,event.clientY);
    app.addFlag = 1;
}
area.addEventListener('click',foo,true);
area.removeEventListener('click',foo,true);</code>

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

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