更新時間:2021-11-30 10:39:59 來源:動力節點 瀏覽2708次
JavaScript添加事件監聽的方法有哪些?小編來告訴大家:
1.我們一般在的事件添加時是這樣做的:
elm.onclick = function( ) { //handler } 這樣的寫法兼容主流的瀏覽器,但是存在一個問題,當同一個elm綁定多個事件時,只有最后一個事件會被添加
如:
elm.onclick = handler1;
elm.onclick = handler2;
elm.onclick = hander3;
只有handler3會被添加執行,所以我們使用另外一種方法添加事件;
2.
attachEvent
elm.attachEvent("onclick",handler1);
elm.attachEvent("onclick",handler2);
elm.attachEvent("onclick",handler3);
三個方法執行的順序是3 - 2 -1;
標準:
addEventListener( ):
elm.addEventListener( "click",handler1,false );
elm.addEventListener( "click",handler2,false );
elm.addEventListener( "click",handler3,false );
執行的順序:1 - 2 - 3
該方法的第三個參數是泡沫獲取,是一個布爾值:當為false時表示由里向外,true表示由外向里:
<div id="id1" >
<div id="id2"></div>
</div>
document.getElementById('id1').addEventListener('click', function() { console.log('id1');}, false);
document.getElementById('id2').addEventListener('click', function() { console.log('id2');}, false);
// 點擊div2 div2 - div1
document.getElementById('id1').addEventListener('click', function() { console.log('id1');}, false);
document.getElementById('id2').addEventListener('click', function() { console.log('id2');}, true);
// 點擊div2 div1 - div2
3.DOM方法 addEventListener() 和 removeEventListener()是用來分配和刪除事件的函數。 這兩個方法都需要三個參數,分別為:
事件名稱(String)、要觸發的事件處理函數(Function)、指定事件處理函數的時期或階段(boolean)。
DOM事件流如圖(剪自javascript高級程序設計):
由圖可知捕獲過程要先于冒泡過程 當第三個參數設置為true就在捕獲過程中執行,反之就在冒泡過程中執行處理函數。
4.通用的事件添加方法:
on:function(elm,type,handler)
// 添加事件
return elm.attachEvent ? elm.attachEvent("on"+type,handler) : elm.addEventListener(type,handler,false);
通過上述相信大家對JS添加事件監聽的方法已經有所了解,大家如果對此比較感興趣,想知道更多的相關知識,可以來關注一下動力節點的JavaScript高級視頻教程,里面的內容豐富,通俗易懂,適合沒有基礎的小白學習,希望對大家能夠有所幫助。
0基礎 0學費 15天面授
有基礎 直達就業
業余時間 高薪轉行
工作1~3年,加薪神器
工作3~5年,晉升架構
提交申請后,顧問老師會電話與您溝通安排學習