Computer >> 컴퓨터 >  >> 프로그램 작성 >> JavaScript

JavaScript의 외부 함수 내부에서 리스너를 제거하시겠습니까?

<시간/>

외부 함수에서 리스너를 제거하려면 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 편집기에서 "실시간 서버로 열기" 옵션을 선택합니다.

출력

이것은 다음과 같은 출력을 생성합니다 -

JavaScript의 외부 함수 내부에서 리스너를 제거하시겠습니까?

"Press Me" 버튼을 클릭한 후

이것은 콘솔에 다음과 같은 출력을 생성합니다 -

JavaScript의 외부 함수 내부에서 리스너를 제거하시겠습니까?