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

Mengapakah peristiwa menggelegak dicetuskan dua kali?

Feb 22, 2024 am 09:06 AM
Acara menggelegak acara klik pencetus dua kali

Mengapakah peristiwa menggelegak dicetuskan dua kali?

Mengapa peristiwa menggelegak dicetuskan dua kali?

Acara menggelegak bermaksud bahawa dalam DOM, apabila elemen mencetuskan acara (seperti acara klik), acara itu akan menggelegak daripada elemen ke elemen induk sehingga ia menggelembung ke atas ke objek dokumen. 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 situasi di mana peristiwa menggelembung dan mencetuskan dua kali, yang biasanya berlaku dalam elemen bersarang. Untuk lebih memahami sebab ia mencetuskan dua kali, mari lihat contoh kod tertentu.

Kod HTML adalah seperti berikut:

<div id="parent">
  <div id="child">
    <button id="button">点击我</button>
  </div>
</div>
Salin selepas log masuk

Kod JavaScript adalah seperti berikut:

var parent = document.getElementById("parent");
var child = document.getElementById("child");
var button = document.getElementById("button");

parent.addEventListener("click", function(event) {
  console.log("父元素被点击");
});

child.addEventListener("click", function(event) {
  console.log("子元素被点击");
});

button.addEventListener("click", function(event) {
  console.log("按钮被点击");
  event.stopPropagation();
});
Salin selepas log masuk

Dalam kod di atas, kami mempunyai elemen induk, elemen anak dan butang, masing-masing terikat pada pendengar acara klik. Apabila kami mengklik butang pada halaman web, acara akan dihantar daripada elemen anak kepada elemen induk mengikut peraturan menggelegak.

Sekarang, mari kita simulasi klik butang. Apabila kita mengklik butang, konsol akan mencetak output berikut:

按钮被点击
子元素被点击
Salin selepas log masuk

Mengapa ia dicetuskan dua kali?

Ini kerana peristiwa menggelegak bermula dari elemen pencetus dan buih sehingga elemen induk mengikut urutan, dan dalam proses ini ia melalui dua lapisan elemen anak dan elemen induk. Apabila kita mengklik butang, peristiwa klik butang pertama kali dicetuskan dan "butang diklik" dicetak. Kemudian, acara itu terus menggelembung ke elemen kanak-kanak, mencetuskan peristiwa klik elemen kanak-kanak dan mencetak "elemen kanak-kanak telah diklik". Akhirnya, menggelegak diteruskan ke elemen induk, mencetuskan peristiwa klik elemen induk.

Jadi bagaimana untuk mengelakkan acara daripada menggelegak dan mencetuskan dua kali?

Kita boleh menghentikan acara daripada menggelegak dengan memanggil event.stopPropagation() dalam pengendali acara klik butang. Dalam kod di atas, kami telah menggunakan kaedah ini dalam acara klik butang. Apabila kita mengklik butang itu sekali lagi, konsol hanya akan mencetak "butang yang diklik" tanpa terus menggelembung ke elemen kanak-kanak dan ibu bapa. event.stopPropagation()来阻止事件继续冒泡。在上述代码中,我们已经在按钮的点击事件中使用了这个方法。当我们再次点击按钮时,控制台将只打印出"按钮被点击",而不会继续冒泡至子元素和父元素。

总结来说,事件冒泡会触发两次的情况通常出现在嵌套元素中,当一个元素触发了某个事件时,事件会从触发元素开始向上冒泡至父元素,直到冒泡到最顶层的文档对象为止。然而,我们可以通过调用event.stopPropagation()

Ringkasnya, acara menggelegak dicetuskan dua kali biasanya dalam elemen bersarang Apabila elemen mencetuskan acara, acara akan menggelegak daripada elemen pencetus ke elemen induk sehingga ia menggelembung ke objek dokumen peringkat atas. Walau bagaimanapun, kita boleh menghalang acara daripada menggelegak dengan memanggil event.stopPropagation(), sekali gus menghalang acara daripada dicetuskan dua kali. 🎜

Atas ialah kandungan terperinci Mengapakah peristiwa menggelegak dicetuskan dua 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

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)

Bangunkan aplikasi desktop yang berkuasa dengan Golang Bangunkan aplikasi desktop yang berkuasa dengan Golang Mar 19, 2024 pm 05:45 PM

Gunakan Golang untuk membangunkan aplikasi desktop yang berkuasa Dengan pembangunan Internet yang berterusan, orang ramai menjadi tidak dapat dipisahkan daripada pelbagai jenis aplikasi desktop. Bagi pembangun, adalah penting untuk menggunakan bahasa pengaturcaraan yang cekap untuk membangunkan aplikasi desktop yang berkuasa. Artikel ini akan memperkenalkan cara menggunakan Golang (bahasa Go) untuk membangunkan aplikasi desktop yang berkuasa dan menyediakan beberapa contoh kod khusus. Golang ialah bahasa pengaturcaraan sumber terbuka yang dibangunkan oleh Google Ia mempunyai ciri-ciri kesederhanaan, kecekapan, konkurensi yang kuat, dsb., dan sangat sesuai untuk

Bagaimana untuk menyediakan lompat pada halaman log masuk layui Bagaimana untuk menyediakan lompat pada halaman log masuk layui Apr 04, 2024 am 03:12 AM

Langkah penetapan lompat halaman log masuk Layui: Tambah kod lompat: Tambah pertimbangan dalam borang log masuk serah acara klik butang, dan lompat ke halaman yang ditentukan melalui window.location.href selepas berjaya log masuk. Ubah suai konfigurasi borang: tambah medan input tersembunyi pada elemen borang lay-filter="login", dengan nama "redirect" dan nilainya ialah alamat halaman sasaran.

Cara menambah acara sentuhan pada gambar dalam vue Cara menambah acara sentuhan pada gambar dalam vue May 02, 2024 pm 10:21 PM

Bagaimana untuk menambah acara klik pada imej dalam Vue? Import contoh Vue. Buat contoh Vue. Tambahkan imej pada templat HTML. Tambahkan acara klik menggunakan arahan v-on:click. Tentukan kaedah handleClick dalam contoh Vue.

Pembangunan bahasa Hongmeng HarmonyOS dan Go Pembangunan bahasa Hongmeng HarmonyOS dan Go Apr 08, 2024 pm 04:48 PM

Pengenalan kepada pembangunan bahasa HarmonyOS dan Go HarmonyOS ialah sistem pengendalian teragih yang dibangunkan oleh Huawei, dan Go ialah bahasa pengaturcaraan moden Gabungan kedua-duanya menyediakan penyelesaian yang berkuasa untuk membangunkan aplikasi teragih. Artikel ini akan memperkenalkan cara menggunakan bahasa Go untuk pembangunan dalam HarmonyOS dan mendalami pemahaman melalui kes praktikal. Pemasangan dan Persediaan Untuk menggunakan bahasa Go untuk membangunkan aplikasi HarmonyOS, anda perlu memasang GoSDK dan HarmonyOSSDK terlebih dahulu. Langkah-langkah khusus adalah seperti berikut: #Install GoSDKgogetgithub.com/golang/go#Set PATH

Petua PHP: Cepat Laksanakan Kembali ke Fungsi Halaman Sebelumnya Petua PHP: Cepat Laksanakan Kembali ke Fungsi Halaman Sebelumnya Mar 09, 2024 am 08:21 AM

Tip PHP: Cepat melaksanakan fungsi kembali ke halaman sebelumnya Dalam pembangunan web, kita sering menghadapi keperluan untuk melaksanakan fungsi kembali ke halaman sebelumnya. Operasi sedemikian boleh meningkatkan pengalaman pengguna dan memudahkan pengguna menavigasi antara halaman web. Dalam PHP, kita boleh mencapai fungsi ini melalui beberapa kod mudah. Artikel ini akan memperkenalkan cara cepat melaksanakan fungsi kembali ke halaman sebelumnya dan memberikan contoh kod PHP tertentu. Dalam PHP, kita boleh menggunakan $_SERVER['HTTP_REFERER'] untuk mendapatkan URL halaman sebelumnya

Apakah mekanisme dipacu peristiwa bagi fungsi C++ dalam pengaturcaraan serentak? Apakah mekanisme dipacu peristiwa bagi fungsi C++ dalam pengaturcaraan serentak? Apr 26, 2024 pm 02:15 PM

Mekanisme dipacu peristiwa dalam pengaturcaraan serentak bertindak balas kepada peristiwa luaran dengan melaksanakan fungsi panggil balik apabila peristiwa berlaku. Dalam C++, mekanisme dipacu peristiwa boleh dilaksanakan dengan penunjuk fungsi: penunjuk fungsi boleh mendaftarkan fungsi panggil balik untuk dilaksanakan apabila peristiwa berlaku. Ungkapan Lambda juga boleh melaksanakan panggilan balik acara, membenarkan penciptaan objek fungsi tanpa nama. Kes sebenar menggunakan penunjuk fungsi untuk melaksanakan peristiwa klik butang GUI, memanggil fungsi panggil balik dan mencetak mesej apabila peristiwa itu berlaku.

Apr 09, 2024 pm 12:45 PM

Jawapan: JavaScript menyediakan pelbagai kaedah untuk mendapatkan elemen halaman web, termasuk menggunakan id, nama teg, nama kelas dan pemilih CSS. Penerangan terperinci: getElementById(id): Dapatkan elemen berdasarkan id unik. getElementsByTagName(tag): Mendapatkan kumpulan elemen dengan nama tag yang ditentukan. getElementsByClassName(class): Mendapatkan kumpulan elemen dengan nama kelas yang ditentukan. querySelector(selector): Gunakan pemilih CSS untuk mendapatkan elemen padanan pertama. querySelectorAll(selector): Dapatkan semua padanan menggunakan pemilih CSS

Takluk dunia GUI dengan Python Tkinter: Panduan lengkap Takluk dunia GUI dengan Python Tkinter: Panduan lengkap Mar 24, 2024 am 09:26 AM

Tkinter ialah kit alat GUI yang berkuasa dalam perpustakaan standard Python untuk mencipta antara muka pengguna grafik (GUI) merentas platform. Ia berdasarkan kit alat Tcl/Tk dan menyediakan sintaks yang mudah dan intuitif, membolehkan pembangun Python mencipta antara muka pengguna yang kompleks dengan mudah dan cepat. Kelebihan keserasian merentas platform Tkinter: Aplikasi Tkinter dijalankan pada semua sistem pengendalian utama seperti tingkap, Mac dan Linux. Mudah digunakan: Sintaksnya jelas dan mudah dipelajari, menjadikannya mudah untuk dikuasai oleh pembangun pemula dan berpengalaman. Kebolehlanjutan: Tkinter menyediakan pelbagai widget dan kawalan, membolehkan pembangun mencipta pelbagai jenis antara muka pengguna. Integrasi: Ia berkaitan dengan P

See all articles