js學(xué)習(xí)總結(jié)之dom2級事件基礎(chǔ)知識詳解
我們使用的DOM2事件綁定,其實(shí)是讓box通過原型鏈一直找到EventTarget這個內(nèi)置類原型上的addEventListener方法實(shí)現(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:當(dāng)頁面中的DOM結(jié)構(gòu)(HTML結(jié)構(gòu)加載完成)觸發(fā)的行為
box.addEventListener('DOMContentLoaded',function(e){ },false)
window.onload = function(){} //當(dāng)頁面中的所有資源都加載完成(圖片、HTML結(jié)構(gòu)、音視頻...)才會執(zhí)行后面的函數(shù);并且在一個頁面中只能用一次,后面在寫會把前面的覆蓋掉;->因?yàn)樗遣捎肈OM0事件綁定,所以只能綁定一次 $(document).ready(function(){})//->$(function(){}) /* 只要頁面中的HTML結(jié)構(gòu)加載完成就會執(zhí)行對應(yīng)的函數(shù);并且在同一個頁面中可以出現(xiàn)多次。因此這個是采用DOM2事件的綁定,綁定的行為是DOMContentLoaded */
DOM2級添加和移除事件細(xì)節(jié)
function fn1(e){ console.log(this); } //添加事件 box.addEventListener('click',fn1,false); //移除事件 box.removeEventListener('click',fn1,false);
注意:移除的時候需要保證三個參數(shù):行為、方法、哪個階段發(fā)生的 三個參數(shù)必須一致 ->DOM2在綁定的時候,我們一般都給他綁定的是實(shí)名函數(shù)
只能給某個元素的同一個行為綁定多個“不同”的方法(如果方法相同了,只能留一個)
當(dāng)行為觸發(fā),會按照綁定的先后順序依次把綁定的方法執(zhí)行;執(zhí)行的this是當(dāng)前被綁定事件的元素本身
function fn1(){ console.log(1); } //添加事件 box.addEventListener('click',fn1,false); box.addEventListener('click',fn1,false);//只輸出一個1
上面涉及一個概念:事件池(用來存儲當(dāng)前元素行為綁定的方法的,瀏覽器自帶的機(jī)制) 如下圖所示
但是在IE6-8瀏覽器中,不支持addEventListener,如果想實(shí)現(xiàn)DOM2事件綁定只能用attachEvent/detachEvent
它只有兩個參數(shù),不能像addEventListener那樣控制在哪個階段發(fā)生,默認(rèn)只能在冒泡階段發(fā)生,同時行為需要添加on(和DOM0特別的類似)
box.attachEvent('onclick',fn1)
注意:和標(biāo)準(zhǔn)瀏覽器的事件池機(jī)制對比:
1、順序問題:執(zhí)行的時候順序是混亂的,標(biāo)準(zhǔn)瀏覽器是按照綁定順序依次執(zhí)行的
2、重復(fù)問題:ie6-8可以給同一個元素的同一個行為綁定多個相同的方法
3、this問題:ie6-8中當(dāng)方法執(zhí)行的時候,方法中的this不是當(dāng)前的元素box而是window
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- JavaScript中DOM操作常用事件總結(jié)
- JavaScript DOMContentLoaded事件案例詳解
- JavaScript WebAPI、DOM、事件和操作元素實(shí)例詳解
- 詳解用js代碼觸發(fā)dom事件的實(shí)現(xiàn)方案
- JS前端知識點(diǎn)總結(jié)之頁面加載事件,數(shù)組操作,DOM節(jié)點(diǎn)操作,循環(huán)和分支
- JS實(shí)現(xiàn)同一DOM元素上onClick事件與onDblClick事件并存的解決方法
- js中DOM事件綁定分析
- JS對象與JSON互轉(zhuǎn)換、New Function()、 forEach()、DOM事件流等js開發(fā)基礎(chǔ)小結(jié)
- JS實(shí)現(xiàn)動態(tài)添加DOM節(jié)點(diǎn)和事件的方法示例
- JavaScript DOM操作與事件處理方法
相關(guān)文章
新增加的內(nèi)容是如何將div的scrollbar自動移動最下面
在做動態(tài)增長的div時,一般都是將內(nèi)容append到div的最下面,但這會帶來一個問題,那就是新增加的內(nèi)容會被遮在最下面,具體實(shí)現(xiàn)如下,感興趣的朋友可以參考下2014-01-01JavaScript裝飾器的實(shí)現(xiàn)原理詳解
最近在使用TS+Vue的開發(fā)模式,發(fā)現(xiàn)項(xiàng)目中大量使用了裝飾器,看得我手足無措,今天特意研究一下實(shí)現(xiàn)原理,方便自己理解這塊知識點(diǎn),有需要的小伙伴也可以參考一下2022-10-10jsonp跨域及實(shí)現(xiàn)百度首頁聯(lián)想功能的方法
這篇文章主要介紹了jsonp跨域及實(shí)現(xiàn)百度首頁聯(lián)想功能的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-08-08JS中字符串切割為數(shù)組/數(shù)組拼接為字符串的代碼例子
這篇文章主要給大家介紹了關(guān)于JS中字符串切割為數(shù)組/數(shù)組拼接為字符串的相關(guān)資料,數(shù)組是JavaScript中最強(qiáng)大的數(shù)據(jù)結(jié)構(gòu),我們常常通過將字符串轉(zhuǎn)換為數(shù)組來解決許多算法,需要的朋友可以參考下2023-09-09javascript設(shè)計(jì)模式 – 狀態(tài)模式原理與用法實(shí)例分析
這篇文章主要介紹了javascript設(shè)計(jì)模式 – 狀態(tài)模式,結(jié)合實(shí)例形式分析了javascript狀態(tài)模式相關(guān)概念、原理、用法及操作注意事項(xiàng),需要的朋友可以參考下2020-04-04一文了解JavaScript中call/apply/bind的使用
這篇文章主要介紹了一文了解JavaScript中call/apply/bind的使用,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的朋友可以參考一下2022-07-07JavaScript實(shí)現(xiàn)手機(jī)號碼 3-4-4格式并控制新增和刪除時光標(biāo)的位置
這篇文章主要介紹了JavaScript實(shí)現(xiàn)手機(jī)號碼 3-4-4格式并控制新增和刪除時光標(biāo)的位置,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-06-06