질문:
JavaScript에서 이벤트 리스너를 효과적으로 제거하는 방법 바인딩() 메서드를 사용하여 추가되었나요?
소개:
bind() 메서드를 사용하면 지정된 컨텍스트로 새 함수를 생성하고 this 키워드를 바인딩할 수 있습니다. 특정 개체. 이는 일반적으로 이벤트 리스너가 호출한 메서드가 올바른 컨텍스트에 액세스할 수 있도록 하는 데 사용됩니다.
예:
다음 시나리오를 고려하세요.
(function () { // MyClass constructor MyClass = function () { this.myButton = document.getElementById("myButtonID"); this.myButton.addEventListener( "click", this.clickListener.bind(this) ); }; MyClass.prototype.clickListener = function (event) { console.log(this); // Should be MyClass }; // Method to disable the button MyClass.prototype.disableButton = function () { // Remove the event listener this.myButton.removeEventListener( "click", this.clickListener_________// Placeholder for missing argument ); }; })();
토론:
바인드()를 사용하여 추가된 모든 리스너를 추적하는 것이 한 가지 가능한 해결책이지만 이 접근 방식은 번거롭고 오류가 발생하기 쉽습니다.
최적의 솔루션:
더 효율적인 솔루션은 바인딩() 메서드가 새로운 함수 참조를 생성한다는 것을 인식하는 것입니다. 따라서 리스너를 제거하려면 참조를 변수에 할당해야 합니다.
const clickListenerBound = this.clickListener.bind(this); this.myButton.addEventListener("click", clickListenerBound);
그런 다음 버튼을 비활성화할 때:
this.myButton.removeEventListener("click", clickListenerBound);
위 내용은 JavaScript에서 바인딩() 메서드를 사용하여 추가된 이벤트 리스너를 제거하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!