js學習總結之dom2級事件基礎知識詳解
我們使用的DOM2事件綁定,其實是讓box通過原型鏈一直找到EventTarget這個內置類原型上的addEventListener方法實現(xiàn)的。
DOM0級事件綁定:只能給一個元素的某一個行為綁定一次方法,第二次綁定的會把前面的覆蓋掉。
DOM2:可以給某一個元素的同一個行為綁定多個不同的方法
box.addEventListener('click',function(e){
console.log(1)
},false)
box.addEventListener('click',function(e){
console.log(2)
},false) // 輸出1 2
DOM2:DOM0中的行為類型,我們用DOM2一樣可以綁定,而且DOM2中還提供了一些DOM0沒有的行為類型->DOMContentLoaded:當頁面中的DOM結構(HTML結構加載完成)觸發(fā)的行為
box.addEventListener('DOMContentLoaded',function(e){
},false)
window.onload = function(){}
//當頁面中的所有資源都加載完成(圖片、HTML結構、音視頻...)才會執(zhí)行后面的函數(shù);并且在一個頁面中只能用一次,后面在寫會把前面的覆蓋掉;->因為他是采用DOM0事件綁定,所以只能綁定一次
$(document).ready(function(){})//->$(function(){})
/*
只要頁面中的HTML結構加載完成就會執(zhí)行對應的函數(shù);并且在同一個頁面中可以出現(xiàn)多次。因此這個是采用DOM2事件的綁定,綁定的行為是DOMContentLoaded
*/
DOM2級添加和移除事件細節(jié)
function fn1(e){
console.log(this);
}
//添加事件
box.addEventListener('click',fn1,false);
//移除事件
box.removeEventListener('click',fn1,false);
注意:移除的時候需要保證三個參數(shù):行為、方法、哪個階段發(fā)生的 三個參數(shù)必須一致 ->DOM2在綁定的時候,我們一般都給他綁定的是實名函數(shù)
只能給某個元素的同一個行為綁定多個“不同”的方法(如果方法相同了,只能留一個)
當行為觸發(fā),會按照綁定的先后順序依次把綁定的方法執(zhí)行;執(zhí)行的this是當前被綁定事件的元素本身
function fn1(){
console.log(1);
}
//添加事件
box.addEventListener('click',fn1,false);
box.addEventListener('click',fn1,false);//只輸出一個1
上面涉及一個概念:事件池(用來存儲當前元素行為綁定的方法的,瀏覽器自帶的機制) 如下圖所示

但是在IE6-8瀏覽器中,不支持addEventListener,如果想實現(xiàn)DOM2事件綁定只能用attachEvent/detachEvent
它只有兩個參數(shù),不能像addEventListener那樣控制在哪個階段發(fā)生,默認只能在冒泡階段發(fā)生,同時行為需要添加on(和DOM0特別的類似)
box.attachEvent('onclick',fn1)
注意:和標準瀏覽器的事件池機制對比:
1、順序問題:執(zhí)行的時候順序是混亂的,標準瀏覽器是按照綁定順序依次執(zhí)行的
2、重復問題:ie6-8可以給同一個元素的同一個行為綁定多個相同的方法
3、this問題:ie6-8中當方法執(zhí)行的時候,方法中的this不是當前的元素box而是window
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
- JavaScript中DOM操作常用事件總結
- JavaScript DOMContentLoaded事件案例詳解
- JavaScript WebAPI、DOM、事件和操作元素實例詳解
- 詳解用js代碼觸發(fā)dom事件的實現(xiàn)方案
- JS前端知識點總結之頁面加載事件,數(shù)組操作,DOM節(jié)點操作,循環(huán)和分支
- JS實現(xiàn)同一DOM元素上onClick事件與onDblClick事件并存的解決方法
- js中DOM事件綁定分析
- JS對象與JSON互轉換、New Function()、 forEach()、DOM事件流等js開發(fā)基礎小結
- JS實現(xiàn)動態(tài)添加DOM節(jié)點和事件的方法示例
- JavaScript DOM操作與事件處理方法
相關文章
JS 判斷某變量是否為某數(shù)組中的一個值的3種方法(總結)
下面小編就為大家?guī)硪黄狫S 判斷某變量是否為某數(shù)組中的一個值的3種方法(總結)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-07-07
javascript與jquery動態(tài)創(chuàng)建html元素示例
這篇文章主要介紹了javascript與jquery動態(tài)創(chuàng)建html元素的方法,結合實例形式分析了javascript與jQuery動態(tài)創(chuàng)建頁面元素的相關技巧,具有一定參考借鑒價值,需要的朋友可以參考下2016-07-07
Javascript實現(xiàn)圖片輪播效果(二)圖片序列節(jié)點的控制實現(xiàn)
這篇文章主要介紹了Javascript實現(xiàn)圖片輪播效果(二)圖片序列節(jié)點的控制實現(xiàn)的相關資料,需要的朋友可以參考下2016-02-02

