외부 함수에서 리스너를 제거하려면 removeEventListener()를 사용하십시오.
예시
다음은 코드입니다 -
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Document</title> </head> <link rel="stylesheet" href="//code.jquery.com/ui/1.12.1/themes/base/jquery-ui.css"> <script src="https://code.jquery.com/jquery-1.12.4.js"></script> <script src="https://code.jquery.com/ui/1.12.1/jquery-ui.js"></script> <body> <button id="demo">Press Me</button> </body> <script> var demoId = document.getElementById('demo'); demoId.addEventListener('click', function fun() { outerFunction(this, fun); }, false); function outerFunction(self, funct) { console.log('outer function is called....'); self.removeEventListener('click', funct, false); console.log("Listener has been removed...") } </script> </html>
위의 프로그램을 실행하기 위해서는 anyName.html(index.html)이라는 파일명을 저장하고 파일을 우클릭하면 된다. VS Code 편집기에서 "실시간 서버로 열기" 옵션을 선택합니다.
출력
이것은 다음과 같은 출력을 생성합니다 -
"Press Me" 버튼을 클릭한 후
이것은 콘솔에 다음과 같은 출력을 생성합니다 -