Apakah cara untuk mengelakkan peristiwa daripada menggelegak?
Kaedah untuk mengelakkan peristiwa menggelegak termasuk kaedah "stopPropagation()", atribut "cancelBubble", pernyataan "return false", kaedah "stopImmediatePropagation()" dan kaedah "preventDefault()" bersama-sama dengan " kaedah stopPropagation()". Pembangun harus memilih kaedah yang sesuai berdasarkan keperluan khusus dan keserasian penyemak imbas Penggunaan kaedah pencegahan gelembung yang betul boleh meningkatkan kesan interaksi.
Sistem pengendalian tutorial ini: sistem Windows 10, komputer DELL G3.
Menghalang acara menggelegak ialah salah satu keperluan biasa dalam pembangunan web Ia boleh menghalang peristiwa daripada diserahkan kepada elemen induk dan elemen nenek moyang yang lain, dan hanya mencetuskan pengendali acara bagi elemen semasa. Dalam perkembangan sebenar, terdapat banyak cara untuk mengelakkan kejadian daripada menggelegak. Artikel ini akan memperincikan lima kaedah yang biasa digunakan untuk mengelakkan peristiwa menggelegak.
1. kaedah stopPropagation()
Kaedah stopPropagation() ialah kaedah yang paling biasa digunakan dan mudah untuk mengelakkan kejadian daripada menggelegak. Kaedah ini boleh menghalang acara daripada menggelegak dengan memanggil fungsi stopPropagation() objek acara. Contohnya adalah seperti berikut:
elem.addEventListener('click', function(event){ event.stopPropagation(); });
Dalam contoh di atas, pengendali acara klik terikat pada elemen melalui fungsi addEventListener() dan kemudian kaedah stopPropagation() dipanggil dalam fungsi pengendali. Selepas memanggil kaedah ini, acara tidak lagi akan dihantar kepada elemen induk dan hanya peristiwa klik elemen semasa akan dicetuskan.
2. cancelBubble attribute
Atribut cancelBubble ialah kaedah yang disediakan oleh penyemak imbas awal IE untuk mengelakkan peristiwa menggelegak, dan masih serasi dengan kebanyakan penyemak imbas moden. Sifat ini akan ditetapkan kepada benar dalam fungsi pengendalian acara untuk mengelakkan acara daripada menggelegak. Contohnya adalah seperti berikut:
elem.onclick = function(event){ event.cancelBubble = true; };
Dalam contoh di atas, penghantaran menggelegak acara klik dihalang dengan menetapkan sifat cancelBubble kepada benar.
3. kembalikan pernyataan palsu
Dalam sesetengah kes, jika anda ingin menghalang kelakuan lalai acara dan menghalang acara daripada menggelegak pada masa yang sama, anda boleh menggunakan kaedah mengembalikan palsu. Contohnya adalah seperti berikut:
elem.onclick = function(event){ // 阻止事件冒泡 event.stopPropagation(); // 阻止事件默认行为 return false; };
Dalam contoh di atas, kedua-dua acara menggelegak dan kelakuan lalai acara dihalang dengan mengembalikan palsu dalam fungsi pengendali acara. Perlu diingat bahawa return false hanya boleh digunakan apabila mengikat secara langsung fungsi pemprosesan acara dan tidak boleh digunakan untuk mengikat acara dengan fungsi addEventListener().
4. kaedah stopImmediatePropagation()
Kaedah stopImmediatePropagation() sangat serupa dengan kaedah stopPropagation() dan boleh digunakan untuk mengelakkan peristiwa daripada menggelegak, tetapi ia juga mempunyai ciri tambahan - ia boleh menghalang pengendali acara lain pada perlaksanaan yang sama. Contohnya adalah seperti berikut:
elem.addEventListener('click', function(event){ console.log('事件处理函数1'); event.stopImmediatePropagation(); }); elem.addEventListener('click', function(event){ console.log('事件处理函数2'); });
Dalam contoh di atas, dengan memanggil kaedah stopImmediatePropagation(), pengendali acara 1 akan menghalang acara daripada menggelegak dan pengendali acara lain tidak akan dilaksanakan. Oleh itu, hanya "Fungsi Pengendalian Acara 1" akan dikeluarkan, tetapi "Fungsi Pengendalian Acara 2" tidak akan dikeluarkan.
5 Kaedah preventDefault() bekerjasama dengan kaedah stopPropagation()
Dalam sesetengah kes, kami bukan sahaja mahu menghalang acara daripada menggelegak, tetapi juga mahu menghalang kelakuan lalai acara (seperti melarang klik pautan. untuk melompat atau menyerahkan borang, dsb.). Pada masa ini, anda boleh menggunakan kaedah preventDefault() dan kaedah stopPropagation() dalam kombinasi. Contohnya adalah seperti berikut:
elem.addEventListener('click', function(event){ event.preventDefault(); event.stopPropagation(); });
Dalam contoh di atas, dengan memanggil kaedah preventDefault(), anda boleh menghalang kelakuan lalai acara klik, seperti lompat pautan atau penyerahan borang. Memanggil kaedah stopPropagation() pada masa yang sama boleh menghalang acara daripada menggelegak dan memastikan bahawa hanya pengendali peristiwa elemen semasa dicetuskan.
Perlu diingat bahawa walaupun kaedah di atas boleh digunakan untuk mengelakkan kejadian menggelegak, dalam penggunaan sebenar, anda harus memilih dengan teliti bila untuk menggunakannya. Penyalahgunaan yang berlebihan untuk mencegah peristiwa menggelegak boleh mengakibatkan peristiwa itu tidak diserahkan kepada elemen induk atau fungsi pemprosesan lain, menjejaskan pengalaman pengguna. Oleh itu, kaedah di atas hendaklah digunakan hanya dalam senario di mana ia benar-benar perlu untuk mengelakkan peristiwa menggelegak, dan kaedah yang berkenaan hendaklah dipilih secara munasabah mengikut keperluan.
Ringkasnya, kaedah untuk menghalang peristiwa menggelegak termasuk menggunakan kaedah stopPropagation(), cancelBubble attribute, return false statement, stopImmediatePropagation() kaedah dan preventDefault() kaedah bersama-sama dengan stopPropagation() kaedah. Setiap kaedah mempunyai senario terpakai sendiri dan pembangun harus memilih berdasarkan keperluan khusus dan keserasian penyemak imbas. Pada masa yang sama, penggunaan kaedah yang munasabah untuk mencegah peristiwa menggelegak boleh meningkatkan kesan interaksi dan pengalaman pengguna.
Atas ialah kandungan terperinci Apakah cara untuk mengelakkan peristiwa daripada menggelegak?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas



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

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.

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.

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().

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 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:

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 peristiwa menggelegak? Analisis mendalam tentang mekanisme menggelegak acara Acara menggelegak ialah konsep penting dalam pembangunan web, yang mentakrifkan cara acara disampaikan pada halaman. Apabila peristiwa pada elemen dicetuskan, peristiwa itu akan dihantar bermula dari elemen paling dalam dan diteruskan ke luar sehingga ia dihantar ke elemen paling luar. Kaedah penyampaian ini adalah seperti buih yang menggelegak di dalam air, maka ia dipanggil peristiwa menggelegak. Dalam artikel ini, kami akan menganalisis mekanisme peristiwa menggelegak secara mendalam. Prinsip acara menggelegak boleh difahami melalui contoh mudah. Katakan kita mempunyai H