Rumah hujung hadapan web tutorial js Mengapakah peristiwa menggelegak dicetuskan beberapa kali?

Mengapakah peristiwa menggelegak dicetuskan beberapa kali?

Feb 24, 2024 pm 08:33 PM
Acara menggelegak ulang pencetus

Mengapakah peristiwa menggelegak dicetuskan beberapa kali?

Mengapa peristiwa menggelegak dicetuskan dua kali?

Dalam pembangunan bahagian hadapan, kita sering menghadapi konsep acara menggelegak. Peristiwa menggelegak bermakna apabila peristiwa tertentu elemen dicetuskan pada halaman, peristiwa itu akan dihantar lapisan demi lapisan ke elemen atas sehingga akhirnya ia dihantar ke objek dokumen.

Namun, kadangkala kita mungkin menghadapi masalah acara menggelegak dan mencetuskan dua kali, walaupun kita hanya mengikat pendengar acara sekali. Jadi mengapa fenomena pencetus berulang berlaku? Mari selami kemungkinan sebab di bawah.

Pertama sekali, kita perlu menjelaskan konsep cara acara menggelegak berfungsi dalam penyemak imbas. Apabila penyemak imbas mencetuskan peristiwa tertentu pada elemen, ia akan melintasi pepohon DOM bermula dari elemen dan menyemak sama ada setiap elemen induk mempunyai pengendali acara yang terikat dengan acara tersebut. Jika pengendali acara ditemui, penyemak imbas melaksanakan pengendali dan meneruskan traversal sehingga ke objek dokumen. Proses ini adalah peristiwa menggelegak.

Walau bagaimanapun, adalah penting untuk ambil perhatian bahawa peristiwa menggelegak bukan sahaja akan diturunkan kepada unsur induk, tetapi juga kepada unsur nenek moyang. Iaitu, peristiwa menggelegak berulang kali mencetuskan pengendali acara pada unsur induk dan nenek moyang. Ini boleh menyebabkan peristiwa itu dicetuskan dua kali.

Jadi persoalannya, mengapa peristiwa menggelegak berpindah kepada unsur nenek moyang? Ini kerana apabila mengikat pendengar acara, kami biasanya menggunakan perwakilan acara. Maksudnya, ikatkan pendengar acara kepada elemen induk, dan kemudian biarkan elemen induk mengendalikan acara dan bukannya elemen anak melalui acara menggelegak.

Jika pendengar acara yang kita ikat wujud pada kedua-dua elemen induk dan elemen moyang, peristiwa menggelegak akan dicetuskan dua kali. Ini kerana semasa penyemak imbas melintasi pepohon DOM, ia menyemak sama ada setiap elemen induk dan elemen nenek moyang mempunyai pengendali acara yang sama terikat padanya. Jika ada, penyemak imbas akan melaksanakannya.

Untuk lebih memahami masalah ini, contoh kod khusus disediakan di bawah:

Kod HTML:

<div id="parent">
  <div id="child">Click me!</div>
</div>
Salin selepas log masuk

Kod JavaScript:

var parent = document.getElementById('parent');
var child = document.getElementById('child');

parent.addEventListener('click', function() {
  console.log('Parent Clicked!');
});

child.addEventListener('click', function() {
  console.log('Child Clicked!');
});
Salin selepas log masuk

Dalam kod di atas, kami telah mengikat klik pada kedua-dua elemen induk dan elemen anak Pendengar acara untuk acara tersebut. Apabila kita mengklik pada elemen kanak-kanak, konsol akan mengeluarkan hasil dua kali: "Anak Diklik!" dan "Ibu Bapa Diklik!". Ini kerana peristiwa menggelegak dicetuskan dua kali, pertama pendengar acara unsur anak dilaksanakan, dan kemudian pendengar acara unsur induk dilaksanakan.

Untuk mengelakkan masalah gelembung acara dicetuskan dua kali, kita boleh menggunakan kaedah stopPropagation() untuk mengelakkan acara daripada terus menggelegak. Sebagai contoh, dalam kod di atas, kita boleh menambah baris kod dalam pendengar acara elemen kanak-kanak:

child.addEventListener('click', function(event) {
  console.log('Child Clicked!');
  event.stopPropagation();
});
Salin selepas log masuk

Selepas menggunakan kaedah stopPropagation(), hanya pendengar acara elemen kanak-kanak akan dilaksanakan dan acara pendengar elemen induk tidak akan dilaksanakan lagi. Dengan cara ini, kita boleh mengelakkan masalah peristiwa menggelegak dan mencetuskan dua kali.

Untuk meringkaskan, sebab mengapa acara menggelegak dicetuskan dua kali adalah kerana acara menggelegak dihantar kepada pengendali acara pada elemen induk dan moyang. Untuk menyelesaikan masalah ini, kita boleh menggunakan kaedah stopPropagation() untuk mengelakkan acara daripada menggelegak ke atas.

Saya berharap melalui pengenalan artikel ini, pembaca dapat memahami dengan lebih komprehensif tentang prinsip acara menggelegak dan mengapa ia dicetuskan dua kali, serta dapat mencari penyelesaian yang berkesan apabila menghadapi masalah ini dalam pembangunan sebenar.

Atas ialah kandungan terperinci Mengapakah peristiwa menggelegak dicetuskan beberapa kali?. 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

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Arahan sembang dan cara menggunakannya
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

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

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.

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

Bagaimana untuk mengekstrak hanya satu keping data pendua dalam pangkalan data Oracle? Bagaimana untuk mengekstrak hanya satu keping data pendua dalam pangkalan data Oracle? Mar 09, 2024 am 09:03 AM

Bagaimana untuk mengekstrak hanya satu keping data pendua dalam pangkalan data Oracle? Dalam operasi pangkalan data harian, kita sering menghadapi situasi di mana kita perlu mengekstrak data pendua. Kadangkala kami ingin mencari salah satu data pendua dan bukannya menyenaraikan semua data pendua. Dalam pangkalan data Oracle, kita boleh mencapai tujuan ini dengan bantuan beberapa pernyataan SQL. Seterusnya, kami akan memperkenalkan cara mengekstrak hanya satu keping data pendua daripada pangkalan data Oracle dan memberikan contoh kod khusus. 1. Gunakan fungsi ROWID ROWID ialah Ora

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

See all articles