JS事件綁定的常用方式實(shí)例總結(jié)
本文實(shí)例講述了JS事件綁定的常用方式。分享給大家供大家參考,具體如下:
常用的事件綁定的幾種方式有三種:
- 直接在 dom 元素上進(jìn)行綁定。
- 用 on 綁定。
- 用 addEventListener、attachEvent 綁定。
一、直接在 dom 元素上進(jìn)行綁定
<input id="btn1" type="button" onclick="test();" />
二、用 on 綁定
兼容性:在IE,F(xiàn)F,Chrome,Safari,Mozilla,Opera下都適用。
// onclick綁定
document.body.onclick = () => {
console.log(111)
}
// 解綁
document.body.onclick = null;
但是,同一個(gè) dom 元素上,on 只能綁定一個(gè)同類型事件,后者會(huì)覆蓋前者,不同類型的事件可以綁定多個(gè)。
三、用 addEventListener、attachEvent 綁定
同一個(gè) dom 元素上,用 addEventListener、attachEvent 可以綁定多個(gè)同類型事件。
但是,addEventListener 事件執(zhí)行順序按照事件綁定的先后順序執(zhí)行;attachEvent 事件執(zhí)行順序則是隨機(jī)的。
addEventListener
// 綁定
document.body.addEventListener('click', bodyClick, false);
// 解綁
document.body.removeEventListener('click', bodyClick, false);
注意:removeEventListener 第二個(gè)參數(shù)要和 addEventListener 指向同一個(gè)函數(shù)才能解綁成功。
addEventListener 的第三個(gè)參數(shù)若為 false,函數(shù)在冒泡階段執(zhí)行;若為 true,函數(shù)在捕獲階段執(zhí)行。默認(rèn)為 false。
<div id="box"> <div id="child"></div> </div>
box.addEventListener("click", function(){
console.log("box");
}, false);
child.addEventListener("click", function(){
console.log("child");
});
// 執(zhí)行順序?yàn)?child box
box.addEventListener("click", function(){
console.log("box");
}, true);
child.addEventListener("click", function(){
console.log("child");
});
// 執(zhí)行順序?yàn)?box child
兼容性
Chrome 和 FireFox 只支持 addEventListener;IE 只支持 attachEvent(IE11開(kāi)始不支持了)。
所以必須對(duì)2種方法做兼容處理。原理是先判斷 attachEvent 是否為真,如果為真則用 attachEvent 綁定事件,否則用 addEventListener 綁定事件。
可以封裝一個(gè)函數(shù)做兼容性處理:
//dom綁定事件的元素,ev事件名,fn執(zhí)行函數(shù)
function myAddEvent(dom, ev, fn){
if(dom.attachEvent){
dom.attachEvent("on"+ev, fn);
}else {
dom.addEventListener(ev, fn, false);
}
}
myAddEvent(d1, "click", ()=>{
console.log(1111)
});
另外
以上三種方式綁定的點(diǎn)擊事件都可以用下面這條語(yǔ)句觸發(fā)
document.getElementById("btn").click();
PS:關(guān)于javascript事件說(shuō)明可參考本站javascript事件與功能說(shuō)明大全:http://tools.jb51.net/table/javascript_event
更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《JavaScript事件相關(guān)操作與技巧大全》、《JavaScript操作DOM技巧總結(jié)》、《JavaScript頁(yè)面元素操作技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》
希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。
相關(guān)文章
輕松實(shí)現(xiàn)js選項(xiàng)卡切換效果
這篇文章主要幫助大家輕松實(shí)現(xiàn)js選項(xiàng)卡切換效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-09-09
javascript計(jì)算當(dāng)月剩余天數(shù)(天數(shù)計(jì)算器)示例代碼
本文介紹了利用Javascript在網(wǎng)頁(yè)上計(jì)算當(dāng)前月份的剩余天數(shù)的方法,大家參考使用吧2014-01-01
javascript設(shè)計(jì)模式之Adapter模式【適配器模式】實(shí)現(xiàn)方法示例
這篇文章主要介紹了javascript設(shè)計(jì)模式之Adapter模式,結(jié)合實(shí)例形式分析了JS適配器模式的原理與具體實(shí)現(xiàn)方法,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2017-01-01
Javascript筆記一 js以及json基礎(chǔ)使用說(shuō)明
JavaScript中的數(shù)據(jù)很簡(jiǎn)潔的。簡(jiǎn)單數(shù)據(jù)只有 undefined, null, boolean, number和string這五種,而復(fù)雜數(shù)據(jù)只有一種,即object。2010-05-05
原生JS實(shí)現(xiàn)實(shí)時(shí)鐘表
這篇文章主要為大家詳細(xì)介紹了原生JS實(shí)現(xiàn)實(shí)時(shí)鐘表,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-08-08
sessionStorage存儲(chǔ)時(shí)多窗口之前能否進(jìn)行狀態(tài)共享解析

