Mengapakah `addEventListener` Melemparkan Ralat dalam MSIE?

Barbara Streisand
Lepaskan: 2024-10-25 01:52:02
asal
601 orang telah melayarinya

Why Does `addEventListener` Throw an Error in MSIE?

Masalah MSIE dan addEventListener dalam Javascript

Apabila cuba menggunakan kaedah addEventListener pada elemen document.getElementById('container') untuk dilaksanakan fungsi "sebelum menyalin" semasa menyalin kandungan pada halaman web, pengguna mungkin menghadapi ralat "Objek tidak menyokong sifat atau kaedah ini" dalam Internet Explorer (MSIE).

Isu ini timbul kerana MSIE memerlukan penggunaan attachEvent dan bukannya kaedah addEventListener standard. Untuk menyelesaikan masalah ini, semak sama ada kaedah addEventListener tersedia dan gunakannya jika ya, sebaliknya gunakan attachEvent:

if (el.addEventListener){
  el.addEventListener('click', modifyText, false); 
} else if (el.attachEvent){
  el.attachEvent('onclick', modifyText);
}
Salin selepas log masuk

Pendekatan lain ialah mencipta fungsi untuk melaksanakan tugas ini:

function bindEvent(el, eventName, eventHandler) {
  if (el.addEventListener){
    el.addEventListener(eventName, eventHandler, false); 
  } else if (el.attachEvent){
    el.attachEvent('on'+eventName, eventHandler);
  }
}

bindEvent(document.getElementById('myElement'), 'click', function () {
  alert('element clicked');
});
Salin selepas log masuk

Argumen ketiga addEventListener ialah useCapture, yang, apabila ditetapkan kepada benar, menunjukkan bahawa penangkapan acara harus dimulakan.

Atas ialah kandungan terperinci Mengapakah `addEventListener` Melemparkan Ralat dalam MSIE?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!