Bind()로 추가된 이벤트 리스너 제거
JavaScript에서 이벤트 리스너로 작업할 때 더 이상 필요하지 않을 때 제거하는 것이 중요합니다. 특히 .bind() 메서드를 사용하여 추가된 경우에는 더욱 그렇습니다.
.bind() 및 이벤트 리스너
.bind() 메서드는 다음과 같은 새 함수를 생성합니다. 특정 컨텍스트가 바인딩되어 있습니다. 이를 통해 함수가 원래 정의된 컨텍스트 외부에서 호출될 수 있습니다. 제공된 예에서:
this.myButton.addEventListener("click", this.clickListener.bind(this));
.bind(this)는 clickListener 내의 this 키워드가 MyClass 인스턴스를 참조하도록 보장하는 새로운 함수를 생성합니다.
리스너 제거
이 예에서 버튼을 비활성화하려면 이벤트 리스너를 제거해야 합니다. 그러나 .bind()는 새로운 함수 참조를 생성하므로 단순히 원래 함수를 제거할 수는 없습니다.
해결책: 함수 참조를 저장
해결책은 저장하는 것입니다. 이벤트 리스너로 추가하기 전에 변수에서 .bind()에 의해 반환된 함수 참조:
const clickListenerBind = this.clickListener.bind(this); this.myButton.addEventListener("click", clickListenerBind);
이제 저장된 참조를 사용하여 리스너를 제거할 수 있습니다:
this.myButton.removeEventListener("click", clickListenerBind);
다른 방법
위에 설명된 방법을 사용하면 .bind()로 추가된 리스너를 올바르게 제거할 수 있지만 선호되는 대안은 없습니다.
위 내용은 .bind() 메서드로 추가된 이벤트 리스너를 제거하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!