웹 프론트엔드 JS 튜토리얼 js 이벤트 바인딩과 이벤트 모니터링, 이벤트 위임 간의 내용에 대한 간략한 분석

js 이벤트 바인딩과 이벤트 모니터링, 이벤트 위임 간의 내용에 대한 간략한 분석

Aug 23, 2018 pm 03:01 PM
이벤트 위임 이벤트 청취 이벤트 바인딩

이 기사의 내용은 js 이벤트 바인딩 및 이벤트 모니터링 및 이벤트 위임에 대한 간략한 분석입니다. 도움이 필요한 친구들이 참고할 수 있기를 바랍니다.

1. 이벤트 바인딩
JavaScript가 사용자 작업에 응답하도록 하려면 먼저 이벤트 처리 기능을 DOM 요소에 바인딩해야 합니다. 소위 이벤트 처리 기능은 사용자 작업을 처리하는 기능입니다. 다른 작업은 다른 이름에 해당합니다.
이벤트 바인딩에는 일반적으로 사용되는 세 가지 방법이 있습니다.
(1) DOM에서 직접 이벤트 바인딩
DOM 요소에 onclick, onmouseover, onmouseout, onmousedown, onmouseup, ondblclick, onkeydown, onkeypress, onkeyup, 등.

<input type="button" value="click me" onclick="hello()"><script>
function hello(){
    alert("hello world!");
}
</script>
로그인 후 복사

(2) JavaScript 코드의 바인딩 이벤트
JavaScript 코드(예: 스크립트 태그 내)의 이벤트 바인딩은 JavaScript 코드를 HTML 태그에서 분리하여 문서 구조를 명확하고 관리 및 개발하기 쉽게 만듭니다.

<input type="button" value="click me" id="btn"><script>
document.getElementById("btn").onclick = function(){
    alert("hello world!");
}
</script>
로그인 후 복사

(3) 이벤트 수신을 사용하여 이벤트 바인딩
이벤트를 바인딩하는 또 다른 방법은 addEventListener() 또는 attachmentEvent()를 사용하여 이벤트 수신 기능을 바인딩하는 것입니다.
이벤트 모니터링
이벤트 모니터링과 관련하여 W3C 사양에서는 캡처 단계, 대상 단계, 버블링 단계의 세 가지 이벤트 단계를 정의합니다.
W3C 사양

element.addEventListener(event, function, useCapture)
로그인 후 복사

event: (필수) 이벤트 이름, 모든 DOM 이벤트를 지원합니다.
function: (필수) 이벤트가 트리거될 때 실행될 함수를 지정합니다.
useCapture: (선택 사항) 이벤트가 캡처 단계에서 실행되는지 아니면 버블링 단계에서 실행되는지 지정합니다. 사실, 캡처. 거짓, 거품. 기본값은 거짓입니다.

<input type="button" value="click me" id="btn1"><script>
document.getElementById("btn1").addEventListener("click",hello);
function hello(){
    alert("hello world!");
}
</script>
로그인 후 복사

IE 표준

element.attachEvent(event, function)
로그인 후 복사

event: (필수) 이벤트 유형입니다. 예를 들어 onclick과 같이 "on"을 추가해야 합니다.
function: (필수) 이벤트가 트리거될 때 실행될 함수를 지정합니다.

<input type="button" value="click me" id="btn2"><script>
document.getElementById("btn2").attachEvent("onclick",hello);
function hello(){
    alert("hello world!");
}
</script>
로그인 후 복사

이벤트 모니터링의 장점
1. 여러 이벤트를 묶을 수 있습니다.
일반 이벤트 바인딩은 마지막 바인딩된 이벤트만 실행합니다. 이벤트 리스너는 여러 기능을 실행할 수 있습니다.

<input type="button" value="click me" id="btn4"><script>
var btn4 = document.getElementById("btn4");
btn4.addEventListener("click",hello1);
btn4.addEventListener("click",hello2);
function hello1(){
    alert("hello 1");
}
function hello2(){
    alert("hello 2");
}
</script>
로그인 후 복사

2. 해당

<input type="button" value="click me" id="btn5"><script>
var btn5 = document.getElementById("btn5");
btn5.addEventListener("click",hello1);//执行了
btn5.addEventListener("click",hello2);//不执行
btn5.removeEventListener("click",hello2);
function hello1(){
    alert("hello 1");
}
function hello2(){
    alert("hello 2");
}
</script>
로그인 후 복사

캡슐화된 이벤트 모니터링

<input type="button" value="click me" id="btn5">//绑定监听事件
function addEventHandler(target,type,fn){
    if(target.addEventListener){
        target.addEventListener(type,fn);
    }else{
        target.attachEvent("on"+type,fn);
    }
}//移除监听事件
function removeEventHandler(target,type,fn){
    if(target.removeEventListener){
        target.removeEventListener(type,fn);
    }else{
        target.detachEvent("on"+type,fn);
    }
}
로그인 후 복사

을 바인딩 해제할 수 있습니다. 이벤트 캡처는 문서에서 이벤트를 트리거하는 노드까지의 프로세스, 즉 하향식 트리거를 의미합니다. 이벤트의 .
이벤트 버블링: 이벤트를 상향식으로 트리거하는 것입니다. 바인딩된 이벤트 메서드의 세 번째 매개변수는 이벤트 트리거 시퀀스가 ​​이벤트 캡처인지 여부를 제어하는 ​​것입니다. true, 이벤트 캡처, false, 이벤트 버블링. 기본값은 false입니다. 이는 이벤트가 버블링됨을 의미합니다.

<p id="parent">
  <p id="child" class="child"></p>
</p>

document.getElementById("parent").addEventListener("click",function(e){
                alert("parent事件被触发,"+this.id);
            })
            document.getElementById("child").addEventListener("click",function(e){
                alert("child事件被触发,"+this.id)
            })

child事件被触发,child
parent事件被触发,parent
로그인 후 복사

결론: 아이가 먼저이고 그다음이 부모입니다. 이벤트가 안쪽에서 바깥쪽으로 순서대로 발생하는 것을 이벤트 버블링이라고 합니다.
이제 세 번째 매개변수의 값을 true로 변경합니다.

document.getElementById("parent").addEventListener("click",function(e){
                alert("parent事件被触发,"+e.target.id);
            },true)
            document.getElementById("child").addEventListener("click",function(e){
                alert("child事件被触发,"+e.target.id)
            },true)parent事件被触发,parentchild事件被触发,child
로그인 후 복사

결론: 먼저 부모, 그 다음 자식입니다. 이벤트가 발생하는 순서가 외부에서 내부로 바뀌는 것이 이벤트 캡쳐입니다.

이벤트 버블링 방지 및 기본 이벤트 방지:
event.stopPropagation() 메서드: 이벤트 버블링을 방지하고 이벤트가 문서로 확산되는 것을 방지하는 메서드이지만, 기본 이벤트는 계속 실행됩니다. 이 방법을 사용할 때 연결을 클릭하면 연결이 계속 열립니다.
event.preventDefault() 메소드: 기본 이벤트를 방지하기 위한 메소드입니다. 이 메소드를 호출하면 연결이 열리지 않지만 버블링이 발생하며 해당 버블링이 해당 이벤트의 상위 요소로 전달됩니다. 이전 레이어
return false : 이 방법은 이벤트 버블링을 방지하고 기본 이벤트를 방지합니다. 이 코드를 작성하면 연결이 열리지 않고 이벤트가 상위 요소로 전달되지 않습니다. false를 반환하는 것으로 이해하면 됩니다. event.stopPropagation()과 event.preventDefault()를 동시에 호출하는 것과 같습니다

2. 이벤트 위임
이벤트 위임은 이벤트를 추가하는 원리를 사용합니다. 실행 효과를 트리거하는 상위 요소 또는 상위 요소입니다.

<input type="button" value="click me" id="btn6">
var btn6 = document.getElementById("btn6");
document.onclick = function(event){    
event = event || window.event;    
var target = event.target || event.srcElement;    
if(target == btn6){
        alert(btn5.value);
    }
}
로그인 후 복사

이벤트 위임의 장점
1. JavaScript 성능을 향상시킵니다. 이벤트 위임은 이벤트 처리 속도를 크게 향상시키고 메모리 사용량을 줄일 수 있습니다

<ul id="list">
  <li id="item1" >item1</li>
  <li id="item2" >item2</li>
  <li id="item3" >item3</li></ul><script>
  var item1 = document.getElementById("item1");
  var item2 = document.getElementById("item2");
  var item3 = document.getElementById("item3");

document.addEventListener("click",function(event){
    var target = event.target;    
    if(target == item1){
        alert("hello item1");
    }else if(target == item2){
        alert("hello item2");
    }else if(target == item3){
        alert("hello item3");
    }
})</script>
로그인 후 복사

2. 요소 변경으로 인한 이벤트 바인딩 수정 없이 DOM 요소를 동적으로 추가합니다.

<ul id="list">
  <li id="item1" >item1</li>
  <li id="item2" >item2</li>
  <li id="item3" >item3</li></ul><script>var list = document.getElementById("list");

document.addEventListener("click",function(event){
    var target = event.target;    
    if(target.nodeName == "LI"){
        alert(target.innerHTML);
    }
})
var node=document.createElement("li");
var textnode=document.createTextNode("item4");
node.appendChild(textnode);
list.appendChild(node);
</script>
로그인 후 복사

관련 권장 사항:

jquery의 on() 바인딩 이벤트 및 off() 바인딩 해제 이벤트에 대한 간략한 토론

JavaScript 이벤트 바인딩의 일반적인 방법과 장단점 분석에 대한 간략한 토론

위 내용은 js 이벤트 바인딩과 이벤트 모니터링, 이벤트 위임 간의 내용에 대한 간략한 분석의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Jquery에서 이벤트를 바인딩하는 방법은 몇 가지입니까? Jquery에서 이벤트를 바인딩하는 방법은 몇 가지입니까? Nov 09, 2020 pm 03:30 PM

jquery에는 이벤트를 바인딩하는 방법이 4가지 있습니다. 즉, 바인딩(), live(), 대리자() 및 on() 메서드는 이벤트를 기존 요소에만 바인딩할 수 있는 반면, live() )는 on입니다. () 및 Delegate()는 모두 향후 새로 추가되는 요소에 대한 이벤트 바인딩을 지원합니다.

UniApp 오류 문제 해결: 'xxx' 이벤트가 바인딩되지 않았습니다. UniApp 오류 문제 해결: 'xxx' 이벤트가 바인딩되지 않았습니다. Nov 25, 2023 am 10:56 AM

UniApp을 사용하여 애플리케이션을 개발할 때 'xxx' 이벤트가 바인딩되지 않음이라는 오류 메시지가 나타날 수 있습니다. 이는 UniApp의 이벤트 바인딩 메커니즘으로 인해 발생하며 이 문제를 해결하려면 올바르게 설정해야 합니다. 1. 문제 원인 UniApp에서는 v-on 명령어를 통해 페이지 구성 요소의 이벤트 바인딩이 완료됩니다. 예를 들어 템플릿에 버튼 구성 요소를 추가합니다. &lt;button@click="onClick"&gt;나를 클릭하세요&lt;/butto

이벤트가 발생하는 것을 효과적으로 방지하는 방법 이벤트가 발생하는 것을 효과적으로 방지하는 방법 Feb 19, 2024 pm 08:25 PM

이벤트 버블링을 효과적으로 방지하려면 특정 코드 예제가 필요합니다. 이벤트 버블링은 요소의 이벤트가 트리거될 때 상위 요소도 동일한 이벤트 트리거를 수신한다는 것을 의미합니다. 이 이벤트 전달 메커니즘은 때때로 웹 개발에 문제를 가져옵니다. 이벤트가 발생하는 것을 효과적으로 중지하는 방법을 배워야 합니다. JavaScript에서는 이벤트 객체의 stopPropagation() 메서드를 사용하여 이벤트 버블링을 중지할 수 있습니다. 이 메서드는 이벤트 핸들러 내에서 호출되어 이벤트가 상위 요소로 전파되는 것을 중지할 수 있습니다.

JavaScript와 Tencent Maps를 활용한 지도 이벤트 모니터링 기능 구현 JavaScript와 Tencent Maps를 활용한 지도 이벤트 모니터링 기능 구현 Nov 21, 2023 pm 04:10 PM

죄송합니다. 전체 코드 예제를 제공할 수는 없습니다. 그러나 참조할 수 있는 기본 아이디어와 샘플 코드 조각을 제공할 수 있습니다. 다음은 JavaScript와 Tencent Map을 결합하여 지도 이벤트 모니터링 기능을 구현하는 간단한 예입니다. //Tencent Map의 API 소개 constscript=document.createElement('script');script.src='https://map.

요소에 이벤트를 추가하는 방법은 무엇입니까? JS 바인딩 이벤트를 구문 분석하는 세 가지 방법 요소에 이벤트를 추가하는 방법은 무엇입니까? JS 바인딩 이벤트를 구문 분석하는 세 가지 방법 Aug 04, 2022 pm 07:27 PM

스크립팅 언어인 JavaScript는 이벤트를 페이지의 요소에 바인딩할 수 있으므로 지정된 이벤트가 발생하면 해당 이벤트 핸들러가 자동으로 호출되어 이벤트를 처리할 수 있습니다. 그렇다면 요소에 이벤트를 추가하는 방법은 무엇입니까? 다음 글에서는 JS에서 이벤트를 바인딩하는 세 가지 방법을 소개하겠습니다. 도움이 되길 바랍니다.

jquery 바인딩 이벤트의 기능은 무엇입니까? jquery 바인딩 이벤트의 기능은 무엇입니까? Mar 20, 2023 am 10:52 AM

jquery 바인딩 이벤트의 기능: 일반 이벤트를 DOM 노드에 바인딩합니다. DOM 노드가 선택되면 사용자가 해당 작업을 제공할 수 있도록 이벤트를 바인딩합니다. jQuery는 바인딩, 라이브, 위임 및 켜기라는 네 가지 이벤트 바인딩 방법을 제공하며 해당 비수신 기능은 바인딩 해제, 다이, 위임 취소 및 끄입니다.

jQuery 이벤트 바인딩 기술에 대한 심층 토론 jQuery 이벤트 바인딩 기술에 대한 심층 토론 Feb 26, 2024 pm 07:36 PM

jQuery는 웹 페이지의 상호 작용을 처리하는 데 널리 사용되는 인기 있는 JavaScript 라이브러리입니다. 그 중 이벤트 바인딩은 jQuery의 중요한 기능 중 하나이며, 이를 통해 이벤트 바인딩을 통해 사용자 상호작용에 대한 응답을 실현할 수 있습니다. 이 기사에서는 jQuery 이벤트 바인딩 기술을 살펴보고 특정 코드 예제를 제공합니다. 1. 이벤트 바인딩의 기본 개념 이벤트 바인딩은 특정 이벤트가 발생했을 때 지정된 작업을 수행하기 위해 DOM 요소에 이벤트 리스너를 추가하는 것을 의미합니다. jQuery에서 원하는 것을 선택하십시오.

Java 익명 내부 클래스에서 이벤트 모니터링을 구현하는 방법은 무엇입니까? Java 익명 내부 클래스에서 이벤트 모니터링을 구현하는 방법은 무엇입니까? May 02, 2024 pm 12:24 PM

익명 내부 클래스를 사용하여 이벤트 모니터링을 구현하므로 별도의 클래스 파일을 만들 필요가 없어 프로세스가 단순화됩니다. 구문은 다음과 같습니다. new{//인터페이스에 선언된 메서드를 구현합니다. 예를 들어 Button 클래스에서 ActionListener 리스너를 추가하려면 버튼을 클릭할 때 actionPerformed 메서드가 메시지를 인쇄하는 익명 내부 클래스를 통해 수행할 수 있습니다. 코드를 단순화하고 가독성을 향상시키지만 지역 변수에만 액세스하고 생성자나 필드가 없습니다.

See all articles