摘要:所有節點中都包含這兩個方法,并且它們都接受個參數要處理的事件名作為事件處理程序的函數和一個布爾值。最后這個布爾值如果是,表示在捕獲階段調用事件處理程序如果是,表示在冒泡階段調用事件處理程序。
事件處理的方法: 1、直接在html中編寫
例如:
但是這樣處理的事件存在兩個缺點,一個是時間差問題,一個是不同瀏覽器對標識符的解析有差異,很可能會在訪問非限定對象成員時出錯。
2、JavaScript指定事件處理程序每個元素都有自己的事件處理程序屬性,這些屬性通常全部小寫,例如onclick。將這種屬性的值設置為一個函數,就可以指定事件處理程序,如下所示:
var btn=document.getElementById("btn"); btn.onclick=function(){ alert("clicked"); }
在此,我們通過文檔對象取得了一個按鈕的引用,然后為它指定了onclick事件處理程序。但要注意,在這些代碼運行以前不會指定事件處理程序,因此如果這些代碼在頁面中位于按鈕后面,就可能在一段事件內怎么單擊都沒有反應。
刪除事件:
btn.onclick=null;
以上都是DOM0級的事件處理方式,而DOM2級事件定義了兩個方法,用于處理指定和刪除事件處理程序的操作:addEventListener()和removeEventListener()。所有DOM節點中都包含這兩個方法,并且它們都接受3個參數:要處理的事件名、作為事件處理程序的函數和一個布爾值。最后這個布爾值如果是true,表示在捕獲階段調用事件處理程序;如果是false,表示在冒泡階段調用事件處理程序。
例如,要再按鈕上為click事件添加處理程序,可以使用以下代碼:
var btn=document.getElementById("myBtn"); btn.addEventListener("click",function(){ alert(this.id); },false);
與DOM0級方法一樣,這里添加的事件處理程序也是在其依附的元素的作用域中運行。
使用DOM2級方法添加事件處理程序的主要好處是可以添加多個事件處理程序。比如:
var btn=document.getElementById("myBtn"); btn.addEventListener("click",function(){ alert(this.id); },false); btn.addEventListener("click",function(){ alert("Hello World"); },false);
這里為按鈕添加了兩個事件處理程序。這兩個事件處理程序會按照添加它們的順序觸發。
通過addEventListener()添加的事件處理程序之恩給你使用removeEventListener()來移除;移除時傳入的參數與添加處理程序時使用的參數相同。這也以為著通過addEventListener()添加的匿名函數將無法移除。因為傳入removeEventListener()中的事件處理程序函數必須與傳入addEventListener()中的相同。
在大多數情況下,都是將事件處理程序添加到事件流的冒泡階段,這樣可以最大限度的兼容各種瀏覽器。最好只在需要在事件到達目標之前截獲它的時候將事件處理程序添加到捕獲階段。
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/85879.html
摘要:個人前端文章整理從最開始萌生寫文章的想法,到著手開始寫,再到現在已經一年的時間了,由于工作比較忙,更新緩慢,后面還是會繼更新,現將已經寫好的文章整理一個目錄,方便更多的小伙伴去學習。 showImg(https://segmentfault.com/img/remote/1460000017490740?w=1920&h=1080); 個人前端文章整理 從最開始萌生寫文章的想法,到著手...
摘要:取消事件的默認行為。阻止事件的派發包括了捕獲和冒泡阻止同一個事件的其他監聽函數被調用。 事件模型 DOM0 級事件模型 -沒有事件流,這種方式兼容所有瀏覽器 // 方式一 將事件直接通過屬性綁定在元素上 / 方式二 獲取到頁面元素后,通過 onclick 等事件,將觸發的方法指定為元素的事件 var btn = document.getElementById(btn) btn....
摘要:事件事件在用戶退出頁面時發生。注意事件同樣觸發了頁面載入事件事件。如圖所示大體一句話描述和支持事件但是或者不支持該事件。瀏覽器兼容情況完美支持不支持文字提醒信息不支持如圖所示使用遇到的凡是標簽都會觸發事件包括這種。 簡介 onunload,onbeforeunload都是在刷新或關閉時調用,可以在腳本中通過 window.onunload來調用。區別在于onbeforeunload在o...
閱讀 659·2023-04-25 15:49
閱讀 3116·2021-09-22 15:13
閱讀 1251·2021-09-07 10:13
閱讀 3477·2019-08-29 18:34
閱讀 2560·2019-08-29 15:22
閱讀 510·2019-08-27 10:52
閱讀 687·2019-08-26 18:27
閱讀 3021·2019-08-26 13:44