Jadual Kandungan
Penggunaan Asas: Cara Menambah Pendengar Acara
Keluarkan pendengar: mengapa menggunakan penyingkiran yang tidak disengajakan
Senario penggunaan dan amalan terbaik
Pemandangan 1: Pemantauan Acara Satu Masa
Senario 2: Bersihkan pendengar ketika komponen dipasang
Adegan 3: mengikat dan mengikat dinamik
Rumah hujung hadapan web tutorial js Mengendalikan acara dengan AddEventListener dan RoveEventListener dalam JavaScript

Mengendalikan acara dengan AddEventListener dan RoveEventListener dalam JavaScript

Jul 05, 2025 am 01:10 AM

AddEventListener digunakan untuk menambah pendengar acara, yang menyokong pelbagai pengikatan tanpa konflik; 02. RoveEventListener digunakan untuk menghapuskan pendengar, yang mesti konsisten dengan parameter apabila menambahkannya, terutamanya fungsi tanpa nama tidak boleh digunakan; 03. Gunakan Option.Sonce untuk mencapai mendengar sekali; 04. Pendengar harus dibersihkan apabila menyahpasang komponen untuk mengelakkan kebocoran ingatan; 05. Pendengar acara boleh terikat secara dinamik atau tidak disatukan mengikut keadaan.

Mengendalikan acara dengan AddEventListener dan RoveEventListener dalam JavaScript

Dalam JavaScript, addEventListener dan removeEventListener adalah cara standard untuk mengendalikan peristiwa. Mereka memberi anda fleksibiliti untuk mengikat dan menyekat pendengar acara tanpa bimbang tentang pendua mengikat atau menimpa pendengar yang ada.

Mengendalikan acara dengan AddEventListener dan RoveEventListener dalam JavaScript

Penggunaan Asas: Cara Menambah Pendengar Acara

Gunakan addEventListener untuk menambah pendengar acara kepada elemen DOM. Sintaks asasnya ialah:

Mengendalikan acara dengan AddEventListener dan RoveEventListener dalam JavaScript
 element.addeventListener (acara, pengendali, pilihan);
  • event adalah jenis acara yang akan didengar, seperti 'click' dan 'keydown' .
  • handler adalah fungsi yang dilaksanakan apabila peristiwa dicetuskan.
  • options adalah parameter pilihan yang mengawal fasa penangkapan/gelembung dan sama ada ia dilaksanakan hanya sekali, dll.

Contohnya:

 const button = document.getElementById ('MyButton');
Button.AdDeventListener ('klik', fungsi () {
  Console.log ('Butang telah diklik');
});

Kelebihan menulis ini ialah anda boleh memanggil addEventListener beberapa kali untuk menambah beberapa pendengar kepada elemen yang sama tanpa mengganggu satu sama lain.

Mengendalikan acara dengan AddEventListener dan RoveEventListener dalam JavaScript

Keluarkan pendengar: mengapa menggunakan penyingkiran yang tidak disengajakan

Jika anda mahu pendengar acara menjadi berkesan hanya dalam keadaan tertentu, anda perlu mengeluarkannya apabila sesuai. Pada masa ini, removeEventListener mesti digunakan:

 elemen.RemoveEventListener (acara, pengendali, pilihan);

Nota: Parameter yang sama mesti diluluskan seperti yang ditambah , terutamanya fungsi handler tidak boleh menjadi fungsi tanpa nama, jika tidak, ia tidak boleh dikeluarkan dengan betul.

Contoh ralat (tidak boleh dikeluarkan):

 Button.AdDeventListener ('klik', fungsi () {
  console.log ('penyingkiran tidak sah');
});
Button.RemoveEventListener ('klik', fungsi () {
  console.log ('penyingkiran tidak sah');
}); // tidak akan berfungsi kerana ini adalah dua rujukan fungsi yang berbeza

Cara yang betul untuk melakukannya:

 fungsi handleclick () {
  Console.log ('Button Clicked');
}

Button.adDeventListener ('klik', handleClick);
Button.RemoveEventListener ('klik', handleClick); // Keluarkan dengan betul

Senario penggunaan dan amalan terbaik

Pemandangan 1: Pemantauan Acara Satu Masa

Kadang -kadang anda hanya mahu pendengar melaksanakan sekali dan kemudian secara automatik tidak dapat dibongkar. Ia boleh dilaksanakan melalui options.once parameter:

 Button.AdDeventListener ('klik', fungsi () {
  console.log ('ia hanya akan mencetuskan sekali');
}, {sekali: benar});

Dengan cara ini, tidak perlu memanggil secara manual removeEventListener .

Senario 2: Bersihkan pendengar ketika komponen dipasang

Dalam rangka kerja front-end moden (seperti React, Vue), semua pendengar acara harus dibersihkan apabila komponen penyebaran untuk mengelakkan kebocoran ingatan.

Sebagai contoh, dalam useefect React:

 useeffect (() => {
  const handleresize = () => {
    console.log ('perubahan saiz tetingkap');
  };

  window.addeventListener ('saiz semula', handlerSize);

  kembali () => {
    window.removeEventListener ('Resize', handlerSize);
  };
}, []);

Kaedah penulisan ini memastikan sumber -sumber dibersihkan tepat pada masanya apabila komponen dipasang.

Adegan 3: mengikat dan mengikat dinamik

Kadang -kadang anda perlu membuat keputusan sama ada untuk membolehkan pendengar acara berdasarkan status anda. Contohnya:

 Let isEnabled = true;

fungsi togglehandler () {
  jika (isenabled) {
    Button.AdDeventListener ('klik', dosomething);
  } else {
    Button.RemoveEventListener ('klik', dosomething);
  }
}

Kaedah ini sesuai untuk senario di mana logik interaktif sering dihidupkan.

Pada dasarnya itu sahaja. Penggunaan munasabah addEventListener dan removeEventListener boleh menjadikan kod anda lebih mudah dikawal dan lebih mudah untuk dikekalkan.

Atas ialah kandungan terperinci Mengendalikan acara dengan AddEventListener dan RoveEventListener 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

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

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.

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!

Artikel Panas

Skop pembolehubah PHP dijelaskan
4 minggu yang lalu By 百草
Petua untuk menulis komen php
4 minggu yang lalu By 百草
Mengulas kod dalam php
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)

Topik panas

Tutorial PHP
1510
276
Skop dan konteks JavaScript maju Skop dan konteks JavaScript maju Jul 24, 2025 am 12:42 AM

Skop JavaScript menentukan skop kebolehcapaian pembolehubah, yang dibahagikan kepada skop global, fungsi dan tahap blok; Konteks menentukan arah ini dan bergantung kepada kaedah panggilan fungsi. 1. Skop termasuk skop global (boleh diakses di mana sahaja), skop fungsi (hanya sah dalam fungsi), dan skop peringkat blok (biarkan dan const sah dalam {}). 2. Konteks pelaksanaan mengandungi objek pembolehubah, rantaian skop dan nilai -nilai ini. Ini menunjukkan kepada global atau tidak ditentukan dalam fungsi biasa, kaedah panggilan kaedah ke objek panggilan, pembina menunjuk ke objek baru, dan juga boleh ditentukan secara jelas oleh panggilan/memohon/mengikat. 3. Penutupan merujuk kepada fungsi mengakses dan mengingati pembolehubah skop luaran. Mereka sering digunakan untuk enkapsulasi dan cache, tetapi boleh menyebabkan

Bagaimana untuk mendapatkan nilai butang radio yang dipilih dengan JS? Bagaimana untuk mendapatkan nilai butang radio yang dipilih dengan JS? Jul 18, 2025 am 04:17 AM

Terdapat dua kaedah teras untuk mendapatkan nilai butang radio yang dipilih. 1. Gunakan QuerySelector untuk mendapatkan item yang dipilih secara langsung, dan gunakan input [NAME = "NAMA-NAMA ANDA"]: Pemilih yang diperiksa untuk mendapatkan elemen yang dipilih dan membaca atribut nilainya. Ia sesuai untuk pelayar moden dan mempunyai kod ringkas; 2. Gunakan Document.GetElementsByName untuk melintasi dan mencari radio yang diperiksa pertama melalui nodelist gelung dan mendapatkan nilainya, yang sesuai untuk senario yang serasi dengan pelayar lama atau memerlukan kawalan manual proses; Di samping itu, anda perlu memberi perhatian kepada ejaan atribut nama, mengendalikan situasi yang tidak dipilih, dan pemuatan kandungan dinamik

Membina iframes kotak pasir yang selamat dengan JavaScript Membina iframes kotak pasir yang selamat dengan JavaScript Jul 16, 2025 am 02:33 AM

Untuk menggunakan JavaScript untuk membuat iframe kotak pasir yang selamat, mula-mula gunakan atribut kotak pasir HTML untuk mengehadkan tingkah laku iframe, seperti melarang pelaksanaan skrip, tingkap pop timbul dan penyerahan bentuk; kedua, dengan menambah token tertentu seperti skrip membenarkan untuk melegakan keizinan seperti yang diperlukan; kemudian menggabungkan postmessage () untuk mencapai komunikasi silang domain yang selamat, sambil mengesahkan sumber mesej dan data yang ketat; Akhirnya elakkan kesilapan konfigurasi biasa, seperti tidak mengesahkan sumber, tidak menubuhkan CSP, dan lain -lain, dan melakukan ujian keselamatan sebelum pergi dalam talian.

Vue 3 Composition API vs Pilihan API: Perbandingan Terperinci Vue 3 Composition API vs Pilihan API: Perbandingan Terperinci Jul 25, 2025 am 03:46 AM

COMPOSISAPI dalam VUE3 lebih sesuai untuk logik dan jenis derivasi yang kompleks, dan OptionsAPI sesuai untuk senario dan pemula yang mudah; 1. Optionsapi menganjurkan kod mengikut pilihan seperti data dan kaedah, dan mempunyai struktur yang jelas tetapi komponen kompleks dipecah -pecah; 2. CompositionAPI menggunakan persediaan untuk menumpukan logik yang berkaitan, yang kondusif untuk penyelenggaraan dan penggunaan semula; 3. Compositionapi menyedari penggunaan semula logik bebas konflik dan parameternya melalui fungsi kompos yang lebih baik daripada Mixin; 4. CompositionAPI mempunyai sokongan yang lebih baik untuk typescript dan derivasi jenis yang lebih tepat; 5. Tidak terdapat perbezaan yang signifikan dalam jumlah prestasi dan pembungkusan kedua -duanya; 6.

Menguasai Corak Konvensyen JavaScript: Pekerja Web vs Java Threads Menguasai Corak Konvensyen JavaScript: Pekerja Web vs Java Threads Jul 25, 2025 am 04:31 AM

Terdapat perbezaan penting antara pekerja web JavaScript dan Javathreads dalam pemprosesan serentak. 1. JavaScript mengamalkan model tunggal-thread. WebWorkers adalah benang bebas yang disediakan oleh penyemak imbas. Ia sesuai untuk melaksanakan tugas-tugas yang memakan masa yang tidak menghalang UI, tetapi tidak dapat mengendalikan DOM; 2. Java menyokong multithreading sebenar dari tahap bahasa, yang dibuat melalui kelas thread, sesuai untuk logik serentak dan pemprosesan sisi serentak; 3. WebWorkers menggunakan postmessage () untuk berkomunikasi dengan benang utama, yang sangat selamat dan terpencil; Benang Java boleh berkongsi ingatan, jadi isu penyegerakan perlu diberi perhatian; 4. Pekerja web lebih sesuai untuk pengkomputeran selari depan, seperti pemprosesan imej, dan

Teknik Debugging Lanjutan untuk Aplikasi JavaScript Kompleks, menggunakan Prinsip Debugger Java Teknik Debugging Lanjutan untuk Aplikasi JavaScript Kompleks, menggunakan Prinsip Debugger Java Jul 17, 2025 am 01:42 AM

Debugging Aplikasi JavaScript kompleks memerlukan alat penggunaan sistematik. 1. Tetapkan titik putus dan titik putus bersyarat untuk memintas proses yang mencurigakan, seperti sebelum masuk fungsi, gelung, panggilan balik asynchronous dan penapis mengikut keadaan; 2. Membolehkan fungsi Blackboxing untuk menyekat gangguan perpustakaan pihak ketiga; 3. Gunakan pernyataan debugger untuk mengawal kemasukan debug berdasarkan penghakiman alam sekitar; 4. Jejak pautan panggilan melalui CallStack, menganalisis laluan pelaksanaan dan status berubah -ubah, dengan itu dengan cekap mencari punca utama masalah.

Meneroka Peraturan Paksaan Jenis dalam JavaScript Meneroka Peraturan Paksaan Jenis dalam JavaScript Jul 21, 2025 am 02:31 AM

Pemutus jenis adalah tingkah laku secara automatik menukar satu jenis nilai kepada jenis lain dalam JavaScript. Senario biasa termasuk: 1. Apabila menggunakan pengendali, jika satu sisi adalah rentetan, sisi lain juga akan ditukar kepada rentetan, seperti '5' 5. Hasilnya ialah "55"; 2. 3. Null mengambil bahagian dalam operasi berangka dan akan ditukar kepada 0, dan undefined akan ditukar kepada NAN; 4. Masalah yang disebabkan oleh penukaran tersirat boleh dielakkan melalui fungsi penukaran eksplisit seperti nombor (), rentetan (), dan boolean (). Menguasai peraturan ini membantu

Membina Sistem Reka Bentuk JavaScript Membina Sistem Reka Bentuk JavaScript Jul 16, 2025 am 02:47 AM

Membina sistem reka bentuk JavaScript memerlukan bermula dari keperluan sebenar dan secara beransur -ansur memperbaikinya. 1. Abstraksi komponen harus "cukup tetapi tidak berlebihan". Pertama, merangkumi komponen biasa dan sifat asas, seperti butang pembolehubah dan kurang upaya, dan kemudian mengembangkan permintaan; 2. Pengurusan gaya harus bersatu dan boleh diperpanjang, menggunakan skema CSS-in-JS, pembolehubah tema dan spesifikasi penamaan bersatu, seperti BEM atau cssmodul; 3. Dokumen dan contoh adalah kunci, dan menggunakan buku cerita untuk menyediakan persembahan visual, meliputi penggunaan, status, jadual prop dan contoh senario sebenar; 4. Sistem reka bentuk memerlukan mekanisme kawalan dan kolaborasi versi, dan memastikan penyelenggaraan berterusan melalui pelepasan NPM, proses kemas kini PR dan penyegerakan alat reka bentuk.

See all articles