Jadual Kandungan
1. Cara mencari sasaran acara EventTarget (gelembung dan tangkap)
2. Mekanisme proksi acara (delegasi acara)
三、e.target与e.currentTarget的区别:
四、阻止冒泡与捕获
六、取消默认事件
Rumah hujung hadapan web tutorial js Ketahui lebih lanjut tentang menggelegak acara dan menangkap dalam JavaScript

Ketahui lebih lanjut tentang menggelegak acara dan menangkap dalam JavaScript

Aug 04, 2022 pm 09:01 PM
javascript Acara menggelegak menangkap peristiwa ejen acara

Artikel ini akan membawa anda melalui acara menggelegak dan menangkap, dan membolehkan anda memahami kaedah carian sasaran acara js (bergelembung dan menangkap), proksi acara, perbezaan antara e.target dan e.currentTarget, mencegah menggelegak dan menangkap, Batal acara lalai, harap ia membantu semua orang!

1. Cara mencari sasaran acara EventTarget (gelembung dan tangkap)

Sasaran acara merujuk kepada elemen yang terikat dengan acara, elemet .addEventListener('click',function(){}) Elemet di sini ialah sasaran acara.

Gelembung dan menangkap:

  • Acara buih:

    • Acara dilaksanakan dengan menggelegak dari bawah ke atas secara lalai. Mengambil peristiwa klik sebagai contoh, apabila kita mengklik pada elemen anak, ia juga boleh mencetuskan peristiwa klik pada elemen induk dan ke atas. Susunan pelaksanaan acara adalah dari bawah ke atas, iaitu acara menggelegak.
  • Acara tangkapan:

    • Sudah tentu, terdapat juga kaedah tangkapan atas ke bawah. Masih mengambil peristiwa klik sebagai contoh, apabila elemen kanak-kanak terikat kepada peristiwa klik, dan kami mengklik pada elemen kanak-kanak, peristiwa klik yang terikat pada elemen induk dan elemen di atas juga akan dilaksanakan. Susunan pelaksanaan acara adalah dari atas ke bawah, iaitu acara tangkapan.

addEventListener(type,listener,useCapture) Analisis ringkas:

  • jenis: acara Taipkan
  • pendengar: fungsi pengendali mendengar acara
  • useCapture: tetapkan kaedah carian acara
    • acara yang salah, menggelegak (nilai lalai)
    • benar, peristiwa tangkap

Penggunaan parameter Analisis tangkapan:

Inti penting! ! Keseluruhan proses mencetuskan sasaran acara dibahagikan kepada dua peringkat (menangkap dan menggelegak). useCapture Nilai ini menentukan pada peringkat mana pencetus sasaran acara dilaksanakan.

Analisis jujukan menggelegak dan menangkap:

Ketahui lebih lanjut tentang menggelegak acara dan menangkap dalam JavaScript

  • Anda boleh melihatnya daripada gambar Dapat dilihat bahawa peristiwa itu ditangkap terlebih dahulu dan kemudian peristiwa itu berbuih. Tangkapan acara adalah dari atas ke bawah (peristiwa luaran dicetuskan dahulu), dan acara menggelegak adalah dari bawah ke atas (peristiwa dalaman dicetuskan dahulu).
  • Proses menangkap adalah daripada tidak spesifik kepada khusus, dan proses menggelegak adalah daripada khusus kepada tidak spesifik.
  • Walaupun 捕获优先, peristiwa menggelegak ialah kaedah penghantaran lalai. Ini bermakna peristiwa dicetuskan dalam peringkat menggelegak secara lalai.
  • Titik! ! Carian untuk sasaran acara dibahagikan kepada dua peringkat: "bubble" dan "capture". Jika terdapat kedua-dua tangkapan dan buih dalam elemen bersarang, tangkapan mesti diutamakan Selepas peristiwa dalam fasa tangkapan dilaksanakan, peristiwa dalam fasa menggelegak akan dilaksanakan.

Demonstrasi kod:

    <div>
        这是div1
        <div>
            这是div2
            <div>这是div3</div>
        </div>
    </div>
    <script>
        let div1 = document.getElementById(&#39;div1&#39;);
        let div2 = document.getElementById(&#39;div2&#39;);
        let div3 = document.getElementById(&#39;div3&#39;);
        div1.addEventListener(&#39;click&#39;,function(){
            console.log("这是div1的点击事件");
        },false);
        div2.addEventListener(&#39;click&#39;,function(){
            console.log("这是div2的点击事件");
        },false);
        div3.addEventListener(&#39;click&#39;,function(){
            console.log("这是div3的点击事件");
        },false);
    </script>
Salin selepas log masuk

Apabila kita mengklik pada div3, seperti yang dapat dilihat daripada keputusan konsol di bawah, acara di sini Mereka semua dilaksanakan dalam fasa menggelegak.

Ketahui lebih lanjut tentang menggelegak acara dan menangkap dalam JavaScript

Masih klik pada div3, kami menukar parameter ketiga div1.addEventListener kepada benar Seperti yang dapat dilihat di bawah, div1 dilaksanakan terlebih dahulu, menunjukkan bahawa fasa tangkapan diutamakan sepanjang fasa menggelegak.

Ketahui lebih lanjut tentang menggelegak acara dan menangkap dalam JavaScript

Pastikan anda menaipnya selepas membaca ini Saya tidak menyenaraikan semua situasi yang lain untuk anda cuba dan ringkaskan untuk memahami perkara di atas, pengekodan sebenar tidak akan menjadi sangat rumit).

Di atas adalah pemahaman saya tentang dua mekanisme 冒泡 dan 捕获 untuk carian sasaran acara.

2. Mekanisme proksi acara (delegasi acara)

Gunakan gelembung acara untuk melengkapkan mekanisme proksi acara:

Salin selepas log masuk
        
  • 列表1
  •     
  • 列表2

Apabila kami ingin mengikat acara klik ke li dalam senarai di atas, klik untuk mendapatkan kandungan dalam li Secara umumnya, kami menggunakan untuk untuk melintasi elemen untuk mengikat acara klik.

let lis = document.querySelectorAll('li');
for (let i = 0; i <p>Jika kita mempunyai 10,000 <code>li</code> nod, kita perlu mengikat 10,000 peristiwa menggunakan kaedah di atas, yang sangat mempengaruhi prestasi kod. Oleh itu, kita boleh menggunakan mekanisme menggelegak untuk menyelesaikan masalah di atas, iaitu mengikat acara dengan elemen induk <code>ul</code>. Lihat kod berikut: </p><pre class="brush:php;toolbar:false">
    
Salin selepas log masuk
            
  • 列表1
  •         
  • 列表2
  •     
    <script> let ul = document.querySelector(&#39;ul&#39;); //我们可以通过事件对象(e)中的target属性可以访问到事件源(也就事件的触发元素) ul.addEventListener(&#39;click&#39;,function(e){ console.log(e.target.innerHTML); },false); </script>

Objek acara (e): Sama ada acara mengikat addEventListener atau langsung ".nama acara", parameter pertama dalam fungsi pemprosesan mendengar acara ialah 事件对象 . Objek acara mengandungi maklumat terperinci tentang acara Contohnya, objek ini mengandungi: sumber acara, id acara, jenis acara, elemen terikat acara, kedudukan yang diklik apabila acara dicetuskan, dsb. Antaranya, e.target boleh mengakses sumber acara, yang merupakan sumber pencetus acara ini.

既然能给父元素绑定事件监听,又能拿到触发的源头。所以我们通过“e.target”+“冒泡机制”就可以减少事件的绑定,能提升不少的性能。

依次点击列表1与列表2:

Ketahui lebih lanjut tentang menggelegak acara dan menangkap dalam JavaScript

总结:通过上面代码我们知道了“事件对象”+“冒泡机制”可以实现事件委托。事件委托就是当事件触发时,通过事件冒泡(或事件捕获)把要做的事委托给父元素来处理。

三、e.target与e.currentTarget的区别:

  • e.target 指向的是触发事件监听的对象(事件源)。
  • e.currentTarget 指向添加监听事件的对象(绑定事件的dom元素)。

四、阻止冒泡与捕获

为什么要阻止冒泡或捕获?

点击当前元素时以冒泡的方式传递事件如果上级元素绑定了同样的事件,就会因为冒泡传递导致触发。同样捕获的过程中,也会触发与当前元素绑定的相同事件的上级。只是触发顺序不同。

事件代理一般使用的冒泡,当然阻止冒泡一般不会影响事件代理,因为顺序问题只会影响捕获事件,这也是为什么都使用冒泡实现事件代理机制。

阻止冒泡或捕获的方法

这里我不考虑兼容性问题,我相信不久将来兼容性可以得到解决。

阻止冒泡w3c推介的方法是event.stopPropagation(),顾名思义停止传播,他是事件对象(event)的方法,此方法是阻止目标元素的继续冒泡(或捕获)

event.stopPropagation()阻止冒泡:

    <div>
        这是div1
        <div>
            这是div2
            <div>这是div3</div>
        </div>
    </div>
    <script>
        let div1 = document.getElementById(&#39;div1&#39;);
        let div2 = document.getElementById(&#39;div2&#39;);
        let div3 = document.getElementById(&#39;div3&#39;);
        div1.onclick = function (e) {
           alert(&#39;div1&#39;);
        }
        div2.onclick = function (e) {
           e.stopPropagation();
            alert(&#39;div2&#39;);
        }
        div3.onclick = function (e) {
           alert(&#39;div3&#39;);
        }
    </script>
Salin selepas log masuk

上面代码默认都是冒泡事件,我们点击div3会依次弹出’div3’与’div2’,为什么没有弹出’div1’这是因为e.stopPropagation();阻止了目标元素的事件继续冒泡到上级。如果每个点击事件都加上了e.topPropagation就不会出现多弹窗的情况。

event.stopPropagation()阻止捕获:

    <div>
        这是div1
        <div>
            这是div2
            <div>这是div3</div>
        </div>
    </div>
    <script>
        let div1 = document.getElementById(&#39;div1&#39;);
        let div2 = document.getElementById(&#39;div2&#39;);
        let div3 = document.getElementById(&#39;div3&#39;);
        div1.addEventListener(&#39;click&#39;,function(e){
           	console.log(&#39;div1&#39;);
        },true);
        div2.addEventListener(&#39;click&#39;,function(e){
            console.log(&#39;div2&#39;);
            e.stopPropagation();
        },true);
        div3.addEventListener(&#39;click&#39;,function(e){
            console.log(&#39;div3&#39;);
        },true);
    </script>
Salin selepas log masuk

当我们点击div2会依次弹出’div1’与’div2’,这也是因为在div2事件中我们设置了e.stopPropagation(),阻塞了目标元素的事件继续向下捕获。

event.target == event.currentTarget:

div.addEventListener('click',function(e){
	if(event.target == event.currentTarget){
        //需要执行的代码
    }
});
Salin selepas log masuk

此方法不过多解释用的不多,如果你理解了上面的内容,这个方法也能理解。

五、补充:为什么要使用addEventListener()

从上面代码不难看出addEventListener()有如下的优点(以下是MDN的原话):

addEventListener() 是 W3C DOM 规范中提供的注册事件监听器的方法。它的优点包括:

  • 它允许给一个事件注册多个监听器。 特别是在使用AJAX库,JavaScript模块,或其他需要第三方库/插件的代码。
  • 它提供了一种更精细的手段控制 listener 的触发阶段。(即可以选择捕获或者冒泡)。
  • 它对任何 DOM 元素都是有效的,而不仅仅只对 HTML 元素有效。

六、取消默认事件

event.preventDefault()

默认事件指的是<a href=""></a><input type="submit"> 标签这类有默认行为的标签,通过点击可以跳转或提交。我们给这类标签绑定一个点击事件,设置事件对象的preventDefault()方法就可以阻止默认事件的发生。

   <a>点击跳转</a>
    <script>
        let a = document.querySelector(&#39;a&#39;);
        addEventListener(&#39;click&#39;,function(e){
            e.preventDefault();
        })
    </script>
Salin selepas log masuk

那么我们如何才能知道一个标签是否有默认事件,打印事件对象的cancelable属性,通过事件执行就可以知道e.cancelable的结果,如果为false表示有默认事件,true则没有。

return false;

事件执行函数中设置return false取消默认事件,但此方法不常用。

【相关推荐:javascript学习教程

Atas ialah kandungan terperinci Ketahui lebih lanjut tentang menggelegak acara dan menangkap dalam JavaScript. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Fahami mekanisme menggelegak acara: Mengapakah klik pada elemen kanak-kanak mempengaruhi acara elemen induk? Fahami mekanisme menggelegak acara: Mengapakah klik pada elemen kanak-kanak mempengaruhi acara elemen induk? Jan 13, 2024 pm 02:55 PM

Memahami peristiwa menggelegak: Mengapakah klik pada elemen kanak-kanak mencetuskan peristiwa pada elemen induk? Peristiwa menggelegak bermaksud bahawa dalam struktur elemen bersarang, apabila elemen anak mencetuskan peristiwa, peristiwa itu akan dihantar ke elemen induk lapisan demi lapisan seperti menggelegak, sehingga elemen induk paling luar. Mekanisme ini membolehkan peristiwa pada elemen kanak-kanak disebarkan ke seluruh pepohon elemen dan mencetuskan semua elemen berkaitan secara bergilir-gilir. Untuk lebih memahami peristiwa menggelegak, mari lihat kod contoh tertentu. Kod HTML: <divid="induk&q

Sebab dan penyelesaian untuk kegagalan jQuery .val(). Sebab dan penyelesaian untuk kegagalan jQuery .val(). Feb 20, 2024 am 09:06 AM

Tajuk: Sebab dan penyelesaian untuk kegagalan jQuery.val() Dalam pembangunan bahagian hadapan, jQuery sering digunakan untuk mengendalikan elemen DOM Kaedah .val() digunakan secara meluas untuk mendapatkan dan menetapkan nilai elemen bentuk. Walau bagaimanapun, kadangkala kita menghadapi situasi di mana kaedah .val() gagal, mengakibatkan ketidakupayaan untuk mendapatkan atau menetapkan nilai elemen borang dengan betul. Artikel ini akan meneroka punca kegagalan .val(), menyediakan penyelesaian yang sepadan dan melampirkan contoh kod tertentu. 1.Kaedah analisis sebab.val().

Mengapakah peristiwa menggelegak dicetuskan dua kali? Mengapakah peristiwa menggelegak dicetuskan dua kali? Feb 22, 2024 am 09:06 AM

Mengapakah peristiwa menggelegak dicetuskan dua kali? Peristiwa menggelegak (Event Bubbling) bermaksud bahawa dalam DOM, apabila elemen mencetuskan acara (seperti acara klik), acara itu akan menggelegak daripada elemen ke elemen induk sehingga ia menggelembung ke objek dokumen peringkat atas. Acara menggelegak ialah sebahagian daripada model acara DOM, yang membolehkan pembangun mengikat pendengar acara kepada elemen induk, supaya apabila elemen anak mencetuskan peristiwa, peristiwa itu boleh ditangkap dan diproses melalui mekanisme menggelegak. Walau bagaimanapun, kadangkala pembangun menghadapi peristiwa yang menggelembung dan mencetuskan dua kali.

Mengapakah peristiwa klik dalam js tidak boleh dilaksanakan berulang kali? Mengapakah peristiwa klik dalam js tidak boleh dilaksanakan berulang kali? May 07, 2024 pm 06:36 PM

Acara klik dalam JavaScript tidak boleh dilaksanakan berulang kali kerana mekanisme menggelegak acara. Untuk menyelesaikan masalah ini, anda boleh mengambil langkah berikut: Gunakan tangkapan peristiwa: Tentukan pendengar acara untuk dicetuskan sebelum acara berbuih. Menyerahkan acara: Gunakan event.stopPropagation() untuk menghentikan acara menggelegak. Gunakan pemasa: cetuskan pendengar acara sekali lagi selepas beberapa ketika.

Apakah senario yang boleh digunakan untuk pengubah suai peristiwa dalam vue? Apakah senario yang boleh digunakan untuk pengubah suai peristiwa dalam vue? May 09, 2024 pm 02:33 PM

Pengubah suai acara Vue.js digunakan untuk menambah gelagat tertentu, termasuk: menghalang gelagat lalai (.prevent) menghentikan acara menggelegak (.stop) acara sekali (.sekali) menangkap acara (.capture) mendengar acara pasif (.pasif) Suai pengubah suai (.self)Pengubah suai kunci (.key)

Mengapakah mekanisme menggelegak peristiwa mencetuskan dua kali? Mengapakah mekanisme menggelegak peristiwa mencetuskan dua kali? Feb 25, 2024 am 09:24 AM

Mengapakah peristiwa menggelegak berlaku dua kali berturut-turut? Peristiwa menggelegak ialah konsep penting dalam pembangunan web Ini bermakna apabila peristiwa dicetuskan dalam elemen HTML bersarang, acara itu akan menggelegak daripada elemen paling dalam kepada elemen paling luar. Proses ini kadangkala boleh menyebabkan kekeliruan Satu masalah biasa ialah peristiwa menggelegak berlaku dua kali berturut-turut. Untuk lebih memahami mengapa peristiwa menggelegak berlaku dua kali berturut-turut, mari kita lihat contoh kod dahulu:

Acara JS mana yang tidak muncul? Acara JS mana yang tidak muncul? Feb 19, 2024 pm 09:56 PM

Apakah situasi dalam acara JS yang tidak akan timbul? Peristiwa menggelegak (Event Bubbling) bermaksud bahawa selepas peristiwa dicetuskan pada elemen tertentu, peristiwa itu akan dihantar ke atas di sepanjang pepohon DOM bermula dari elemen paling dalam ke elemen paling luar Kaedah penghantaran ini dipanggil acara menggelegak. Walau bagaimanapun, tidak semua acara boleh menggelegak. Terdapat beberapa kes khas di mana acara tidak akan muncul. Artikel ini akan memperkenalkan situasi dalam JavaScript di mana acara tidak akan muncul. 1. Gunakan stopPropagati

Apakah cara biasa untuk mengelakkan kejadian menggelegak? Apakah cara biasa untuk mengelakkan kejadian menggelegak? Feb 19, 2024 pm 10:25 PM

Apakah arahan yang biasa digunakan untuk mengelakkan peristiwa menggelegak? Dalam pembangunan web, kami sering menghadapi situasi di mana kami perlu mengendalikan acara menggelegak. Apabila peristiwa dicetuskan pada elemen, seperti peristiwa klik, elemen induknya juga akan mencetuskan peristiwa yang sama. Tingkah laku penyampaian acara ini dipanggil acara menggelegak. Kadangkala, kami ingin menghalang acara daripada menggelegak, supaya acara itu hanya menyala pada elemen semasa dan menghalangnya daripada dihantar kepada elemen unggul. Untuk mencapai matlamat ini, kita boleh menggunakan beberapa arahan biasa yang menghalang peristiwa menggelegak. acara.stopPropa

See all articles