웹 프론트엔드 JS 튜토리얼 프런트 엔드에서 이벤트 전파를 방지하는 방법

프런트 엔드에서 이벤트 전파를 방지하는 방법

May 24, 2018 am 11:01 AM
이벤트 확산 예방하다

이번에는 프런트엔드에서 이벤트 확산을 방지하는 방법을 알려드리겠습니다. 프런트엔드에서 이벤트 확산을 방지하기 위한 주의사항은 무엇인가요? 실제 사례를 살펴보겠습니다.

작은 데모를 만들고, 버튼을 클릭하여 플로팅 레이어를 표시하고, 다른 곳을 클릭하여 플로팅 레이어를 닫고, 간단한 CSS를 작성하세요.

<style>
.wrapper{
    position:relative;
    display:inline-block;
}
.popover{
    position:absolute;
    border:1px solid red;
    left:100%;
    top:0;
    padding:10px;
    margin-left:10px;
    background:white;
    display: none;  /*默认隐藏*/
}
.popover::before{
    position:absolute;
    content:'';
    top:5px;
    right:100%;
    border:10px solid transparent;
    border-right-color:red;
}
.popover::after{
    position:absolute;
    content:'';
    top:5px;
    right:100%;
    border:10px solid transparent;
    border-right-color:white;
    margin-right:-1px;
}

</style>
<p id="wrapper" class=&#39;wrapper&#39;>
    <button id="clickMe">点我</button>
    <p id="popover" class="popover">
        <input type="checkbox">浮层
    </p>
</p>
<script>
    clickMe.addEventListener('click',function(){
        popover.style.display = 'block';
    });
</script>
로그인 후 복사

이제 페이지의 빈 공간을 클릭하여 닫으면 어떻게 될까요? 어떤 방법을 써야 할까요? 아래 코드처럼 문서 모니터링을 생각하면 쉽죠

document.addEventListener('click',function(){
    popover.stely.display = 'none';
});
로그인 후 복사

그런데 실제로 이렇게 작성하고 나면 버튼이 무효가 되고 어떻게 눌러도 반응이 없습니다. 왜 이런가요?
이전 글에서 언급한 캡처 및 버블링 이벤트를 이해하고 나면 []()를 쉽게 이해할 수 있습니다.
모니터링이 캡처 단계인지 버블링 단계인지 지정하지 않았습니다. 브라우저는 기본적으로 버블링 단계로 설정되어 있습니다. 버튼을 클릭하면 캡처 단계가 발생하지 않지만 먼저 버튼이 다릅니다. 코드의 함수>가 먼저 실행된 다음 <code>문서의 함수도 실행되어 플로팅 레이어가 다시 숨겨진 것처럼 보입니다. button上函数先触发,然后document上函数也触发了,导致准备出现的浮层又被隐藏了。
那你可能要问,button上的事件执行了没?其实这两个事件都执行了,只是时间太短,浏览器默认一起执行了,可以在里面加一个debugger,就可以看到了。

clickMe.addEventListener('click',function(){
    popover.style.display = 'block';
});
로그인 후 복사

那该怎么解决呢?最简单的方法是,除了要执行popover.style.display = 'block',还要阻止事件传播

clickMe.addEventlistener('click',function(){
    popover.style.display = 'block';
});

popover.addEventListener('click',function(e){
    e.stopPropagation();
});
로그인 후 복사

这里为什么添加在按钮的父元素上面呢?如果不添加在父元素上面,点击浮层的时候,浮层也会被关闭。

如果页面上有很多监听器的话,这个方法是比较浪费内存的,比较省内存的方法用JQuery 做

$(clickMe).on('click',function(){
    $(popover).show();
    $(document).one('click',function(){
        $(popover).hide();
    });
});
$(wrapper).on('click',function(e){
    e.stopPropagation();    
})
로그인 후 복사

一开始不监听,只在popover`show`的时候监听一次,马上关掉,这叫做清理战场。
$(wrapper).on('click',false) 和下面的代码完全等价

$(wrapper).on('click',function(e){
    e.preventDefault();     //阻止默认事件
    e.stopPropagation();    //阻止传播
})
로그인 후 복사

但是如果页面中有checkbox,你在它的父元素任何一层,包括checkbox自己,添加了组织默认事件那么这个checkbox就没办法被check

这里有个问题,如果没有阻止事件传播,向下面这样,会发生什么事情呢?

$(clickMe).on('click',function(){
    $(popover).show();
    $(document).one('click',funtion(){
        $(popover).hide();
    });
});
로그인 후 복사

当然了,和之前一样,什么事情也不会发生,那当我点击按钮之后里面都发生了那些事情呢?
当我点击了按钮之后,它会做两件事情,首先把popover`show出来,然后把hide函数添加到document上面,当事件传播到document`,就会又把它给隐藏了。

可以给它添加一个setTimeout()函数来解决这个问题

$(clickMe).on('click',function(){
    $(popover).show();
    setTimeout(function(){
        $(document).one('click',function(){
            $(popover).hide();
        })
    },0)
});
로그인 후 복사

setTimeout(fn,0)这个0不是马上执行,而是尽快执行,具体是在冒泡结束在执行这里的函数,也就是说,当冒泡结束后,在把监听事件添加到document上面,等待用户下次点击在执行。

总结:

  1. 同时监听buttondocument,点啥都没反应,因为两个函数都执行了,用阻止事件传播解决了,比较浪费内存

  2. 好一定的方法是用jQuery 做,点击button后在监听document,关闭了就不再监听,不阻止事件传播,点啥也没反应,两种解决方法:一种是阻止事件传播,另一种是添加一个setTimeout()그렇다면 버튼의 이벤트가 실행되었나요? 실제로는 두 이벤트가 모두 실행되는데 시간이 너무 짧습니다. 브라우저에서는 기본적으로 함께 실행합니다. 내부에 디버거를 추가하면 볼 수 있습니다.

    rrreee
  3. 그럼 어떻게 해결하나요? 가장 간단한 방법은 popover.style.display = 'block'을 실행하는 것 외에도 이벤트가 전파되는 것을 방지하는 것입니다
rrreee

여기서 버튼의 상위 요소에 추가되는 이유는 무엇인가요? 상위 요소에 추가되지 않은 경우 플로팅 레이어를 클릭하면 닫힙니다.

페이지에 리스너가 많은 경우 이 방법은 메모리 낭비입니다. 메모리를 더 절약하는 방법은 JQuery를 사용하는 것입니다.

rrreee

처음에는 수신하지 않고 popover`show 때만 수신합니다. ` 한 번 모니터링하고 즉시 끄는 것을 전장 청소라고 합니다. $(wrapper).on('click',false)는 다음 코드와 완전히 동일합니다. rrreee
그러나 페이지에 체크박스가 있으면 체크박스 자체를 포함한 요소의 레이어가 조직 기본 이벤트를 추가하는 경우 이 체크박스체크될 수 없습니다.

여기서 궁금한 점이 있습니다. 이벤트 확산을 막지 못하면 아래와 같이 어떻게 되나요? rrreee물론 이전처럼 아무 일도 일어나지 않을 텐데 버튼을 눌렀을 때 무슨 일이 일어났나요?
버튼을 클릭하면 먼저 popover`show가 나오고 hide 기능이 에 추가됩니다. >document 위에서 이벤트가 document`로 전파되면 다시 숨겨집니다.

setTimeout() 함수를 추가하면 이 문제를 해결할 수 있습니다rrreeesetTimeout(fn,0)0은(는) 그렇지 않습니다. 즉, 버블링이 끝나면 청취 이벤트를 document에 추가하고 기다립니다. 사용자는 다음 번에 구현을 클릭해야 합니다.

요약:

  1. 버튼문서를 동시에 모니터링하면 클릭해도 아무 일도 일어나지 않습니다. , 왜냐하면 둘 다 함수가 모두 실행되고 메모리 낭비인 이벤트 전파를 방지하여 문제가 해결되기 때문입니다🎜🎜
  2. 🎜제이쿼리를 사용하는 것이 가장 좋은 방법은 버튼을 클릭한 다음 document 를 들어보세요. 꺼져 있으면 더 이상 듣지 않고, 이벤트 전파를 막지 않으며, 클릭해도 아무 일도 일어나지 않습니다. 두 가지 해결 방법이 있습니다. 하나는 방지하는 것입니다. 이벤트 전파와 다른 하나는 setTimeout() 함수를 추가하는 것입니다. 🎜🎜🎜🎜이 기사의 사례를 읽으신 후 방법을 마스터하셨다고 생각합니다. 더 흥미로운 정보를 보려면 PHP 중국어 웹사이트의 다른 관련 기사를 주목하세요! 🎜🎜추천 도서: 🎜🎜🎜React-router v4 사용 단계에 대한 자세한 설명🎜🎜🎜🎜🎜Chart.js 경량 차트 라이브러리 사용 사례 분석🎜🎜🎜🎜🎜Chart.js 경량 차트 사용 단계에 대한 자세한 설명 HTML5 차트 그리기 도구 라이브러리 🎜🎜🎜🎜🎜

위 내용은 프런트 엔드에서 이벤트 전파를 방지하는 방법의 상세 내용입니다. 자세한 내용은 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)

이벤트 ID 4660: 개체가 삭제되었습니다. [수정] 이벤트 ID 4660: 개체가 삭제되었습니다. [수정] Jul 03, 2023 am 08:13 AM

독자 중 일부는 이벤트 ID4660을 경험했습니다. 그들은 무엇을 해야 할지 확신하지 못하는 경우가 많으므로 이 가이드에서 이에 대해 설명합니다. 이벤트 ID 4660은 일반적으로 개체가 삭제될 때 기록되므로 컴퓨터에서 이 문제를 해결할 수 있는 몇 가지 실용적인 방법도 살펴보겠습니다. 이벤트 ID4660이란 무엇입니까? 이벤트 ID 4660은 Active Directory의 개체와 관련되어 있으며 다음 요소에 의해 트리거됩니다. 개체 삭제 – Active Directory에서 개체가 삭제될 때마다 이벤트 ID 4660이 포함된 보안 이벤트가 기록됩니다. 수동 변경 - 사용자 또는 관리자가 개체의 사용 권한을 수동으로 변경할 때 이벤트 ID 4660이 생성될 수 있습니다. 이는 권한 설정을 변경하거나, 액세스 수준을 수정하거나, 사람이나 그룹을 추가 또는 제거할 때 발생할 수 있습니다.

iPhone 잠금 화면에서 예정된 캘린더 이벤트 받기 iPhone 잠금 화면에서 예정된 캘린더 이벤트 받기 Dec 01, 2023 pm 02:21 PM

iOS 16 이상을 실행하는 iPhone에서는 예정된 캘린더 이벤트를 잠금 화면에 직접 표시할 수 있습니다. 이 작업이 어떻게 수행되었는지 알아보려면 계속 읽어보세요. 시계 페이스 컴플리케이션 덕분에 많은 Apple Watch 사용자는 손목을 통해 다음 캘린더 이벤트를 확인하는 데 익숙합니다. iOS16 및 잠금 화면 위젯의 등장으로 기기 잠금을 해제하지 않고도 iPhone에서 직접 동일한 캘린더 이벤트 정보를 볼 수 있습니다. 캘린더 잠금 화면 위젯은 두 가지 형태로 제공되며, 다음 예정된 이벤트 시간을 추적하거나 이벤트 이름과 시간을 표시하는 더 큰 위젯을 사용할 수 있습니다. 위젯 추가를 시작하려면 Face ID 또는 Touch ID를 사용하여 iPhone을 잠금 해제하고 길게 누르세요.

Edge에서 웹사이트에 대한 액세스를 차단하는 방법 Edge에서 웹사이트에 대한 액세스를 차단하는 방법 Jul 12, 2023 am 08:17 AM

자녀 보호, 시간 관리, 콘텐츠 필터링 또는 보안 문제 등 다양한 이유로 Microsoft Edge에서 특정 웹 사이트를 차단하려는 경우가 있습니다. 일반적인 동기는 생산성을 높이고 집중력을 유지하는 것입니다. 주의를 산만하게 하는 웹사이트를 차단함으로써 사람들은 작업이나 공부에 도움이 되는 환경을 조성하고 주의를 산만하게 할 가능성을 최소화할 수 있습니다. 마지막으로 콘텐츠 필터링은 안전하고 존중받는 온라인 환경을 유지하는 데 중요합니다. 노골적이거나 공격적이거나 불쾌한 콘텐츠가 포함된 웹 사이트를 차단하는 것은 적절한 표준과 가치를 유지하는 것이 중요한 교육 또는 전문 환경에서 특히 중요합니다. 이 상황에 공감할 수 있다면 이 기사가 도움이 될 것입니다. Edge에서 인터넷 액세스를 차단하는 방법은 다음과 같습니다.

JavaScript에서 'oninput' 이벤트의 목적은 무엇입니까? JavaScript에서 'oninput' 이벤트의 목적은 무엇입니까? Aug 26, 2023 pm 03:17 PM

입력 상자에 값이 추가되면 oninput 이벤트가 발생합니다. JavaScript에서 oninput 이벤트를 구현하는 방법을 이해하려면 다음 코드를 실행해 보세요. - 예<!DOCTYPEhtml><html> <body> <p>아래 쓰기:</p> <inputtype="text&quot

jQuery에서 선택 요소의 변경 이벤트 바인딩을 구현하는 방법 jQuery에서 선택 요소의 변경 이벤트 바인딩을 구현하는 방법 Feb 23, 2024 pm 01:12 PM

jQuery는 DOM 조작, 이벤트 처리, 애니메이션 효과 등을 단순화하는 데 사용할 수 있는 인기 있는 JavaScript 라이브러리입니다. 웹 개발에서 우리는 선택 요소에 대한 이벤트 바인딩을 변경해야 하는 상황에 자주 직면합니다. 이 기사에서는 jQuery를 사용하여 선택 요소 변경 이벤트를 바인딩하는 방법을 소개하고 특정 코드 예제를 제공합니다. 먼저 라벨을 사용하여 옵션이 포함된 드롭다운 메뉴를 만들어야 합니다.

Jquery에서 일반적으로 사용되는 이벤트는 무엇입니까? Jquery에서 일반적으로 사용되는 이벤트는 무엇입니까? Jan 03, 2023 pm 06:13 PM

jquery에서 일반적으로 사용되는 이벤트는 다음과 같습니다. 1. 창 이벤트 2. 마우스 클릭, 이동 이벤트, 이동 이벤트 등을 포함하여 사용자가 문서에서 마우스를 이동하거나 클릭할 때 생성되는 이벤트입니다. 3. 키보드 이벤트, 키 누르기 이벤트, 키 놓기 이벤트 등을 포함하여 사용자가 키보드의 키를 누르거나 놓을 때마다 이벤트가 생성됩니다. 4. 요소가 포커스를 얻을 때와 같은 폼 이벤트, focus(); 이벤트가 트리거되고 포커스를 잃으면 Blur() 이벤트가 트리거되고 양식이 제출될 때 submit() 이벤트가 트리거됩니다.

클로저에서 메모리 누수를 효과적으로 방지하는 방법은 무엇입니까? 클로저에서 메모리 누수를 효과적으로 방지하는 방법은 무엇입니까? Jan 13, 2024 pm 12:46 PM

클로저에서 메모리 누수를 방지하는 방법은 무엇입니까? 클로저는 함수 중첩 및 데이터 캡슐화를 가능하게 하는 JavaScript의 가장 강력한 기능 중 하나입니다. 그러나 클로저는 특히 비동기 및 타이머를 처리할 때 메모리 누수가 발생하기 쉽습니다. 이 문서에서는 클로저에서 메모리 누수를 방지하는 방법을 설명하고 구체적인 코드 예제를 제공합니다. 메모리 누수는 일반적으로 객체가 더 이상 필요하지 않지만 어떤 이유로 객체가 차지하는 메모리를 해제할 수 없을 때 발생합니다. 클로저에서 함수가 외부 변수를 참조하고 이러한 변수는

칭화옵틱스 AI가 자연에 등장! 물리적 신경망, 역전파는 더 이상 필요하지 않습니다. 칭화옵틱스 AI가 자연에 등장! 물리적 신경망, 역전파는 더 이상 필요하지 않습니다. Aug 10, 2024 pm 10:15 PM

빛을 사용하여 신경망을 훈련시킨 Tsinghua University의 결과가 최근 Nature에 게재되었습니다! 역전파 알고리즘을 적용할 수 없으면 어떻게 해야 합니까? 그들은 기존 디지털 컴퓨터 시뮬레이션의 한계를 극복하고 물리적 광학 시스템에서 직접 훈련 과정을 수행하는 FFM(Fully Forward Mode) 훈련 방법을 제안했습니다. 간단히 말해서, 예전에는 물리적 시스템을 세부적으로 모델링한 다음 이러한 모델을 컴퓨터에서 시뮬레이션하여 네트워크를 훈련시키는 것이 필요했습니다. FFM 방법은 모델링 프로세스를 제거하고 시스템이 학습 및 최적화를 위해 실험 데이터를 직접 사용할 수 있도록 합니다. 이는 또한 훈련이 더 이상 각 계층을 뒤에서 앞으로 확인할 필요가 없지만(역전파) 네트워크의 매개변수를 앞에서 뒤로 직접 업데이트할 수 있음을 의미합니다. 퍼즐, 역전파와 같은 비유를 사용하려면

See all articles