Mengapa `addEventListener` tidak berfungsi untuk Acara \'copy\' dalam MSIE?

Barbara Streisand
Lepaskan: 2024-10-25 07:17:02
asal
186 orang telah melayarinya

Why Doesn't `addEventListener` Work for the 'copy' Event in MSIE?

Menyelesaikan Isu addEventListener dalam MSIE

Dalam Javascript, percubaan untuk melaksanakan acara 'salinan' menggunakan addEventListener mungkin mengakibatkan ralat berikut dalam MSIE:

<code class="javascript">document.getElementById('container').addEventListener('copy',beforecopy,false );
Object doesn't support this property or method</code>
Salin selepas log masuk

Penyelesaian

MSIE menyimpang daripada pendekatan addEventListener standard dan sebaliknya memerlukan penggunaan 'attachEvent'. Ini boleh dicapai melalui semakan bersyarat:

<code class="javascript">if (el.addEventListener){
  el.addEventListener('click', modifyText, false); 
} else if (el.attachEvent){
  el.attachEvent('onclick', modifyText);
}</code>
Salin selepas log masuk

Sebagai alternatif, fungsi tersuai boleh dibuat untuk mengabstraksikan proses ini:

<code class="javascript">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');
});</code>
Salin selepas log masuk

Bonus: Parameter Ketiga (useCapture)

Argumen ketiga addEventListener ('useCapture') menentukan keutamaan pengendalian acara. Jika ditetapkan kepada benar, ini menunjukkan bahawa penangkapan peristiwa diingini, di mana peristiwa itu dikendalikan pada nenek moyang elemen sebelum mencapai elemen sasaran.

Atas ialah kandungan terperinci Mengapa `addEventListener` tidak berfungsi untuk Acara \'copy\' 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