JavaScript給事件委托批量添加事件監(jiān)聽詳細流程
1.什么是事件委托
事件委托:利用事件冒泡的特性,將本應該注冊在子元素上的處理事件注冊在父元素上,這樣點擊子元素時發(fā)現其本身沒有相應事件就到父元素上尋找作出相應。這樣做的優(yōu)勢有:
- 減少DOM操作,提高性能。
- 隨時可以添加子元素,添加的子元素會自動有相應的處理事件。
2.事件委托的原理
事件委托是利用事件的冒泡原理來實現的,何為事件冒泡呢?就是事件從最深的節(jié)點開始,然后逐步向上傳播事件。
舉個例子:頁面上有這么一個節(jié)點樹,div>ul>li>a;比如給最里面的a加一個click點擊事件,那么這個事件就會一層一層的往外執(zhí)行,執(zhí)行順序a>li>ul>div,有這樣一個機制,那么我們給最外面的div加點擊事件,那么里面的ul,li,a做點擊事件的時候,都會冒泡到最外層的div上,所以都會觸發(fā),這就是事件委托,委托它們父級代為執(zhí)行事件。
3.事件委托的實現
通過一個案例來實現事件委托。
案例:批量添加事件監(jiān)聽。使用JavaScript實現:點擊哪個li,哪個li元素的背景變紅。

結構層+樣式層代碼:
<style>
* {
margin: 0;
padding: 0;
}
ul {
float: left;
width: 800px;
margin-top: 50px;
}
ul li {
list-style: none;
float: left;
width: 200px;
height: 200px;
border: 1px solid #000;
margin-right: 20px;
}
ul li:first-child {
margin-left: 20px;
}
</style>
<body>
<ul id="list">
<li>1</li>
<li>2</li>
<li>3</li>
</ul>
</body>
3.1 方法1:循環(huán)添加事件
不使用事件委托,使用for循環(huán)添加點擊事件,內存消耗大。
var oList = document.getElementById('list');
var lis = oList.getElementsByTagName('li');
for (var i = 0; i < lis.length; i++) {
lis[i].onclick = function () {
this.style.backgroundColor = 'red';
}
}
3.2 方法2:使用事件委托
使用事件委托。
var oList = document.getElementById('list');
oList.onclick = function (e) {
e.target.style.backgroundColor = 'red';
}
該案例中,e.target表示用戶真正點擊到的那個元素。
到此這篇關于JavaScript給事件委托批量添加事件監(jiān)聽詳細流程的文章就介紹到這了,更多相關JavaScript 事件委托內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
JavaScript實現iframe自動高度調整和不同主域名跨域
這篇文章主要介紹了JavaScript實現iframe自動高度調整和不同主域名跨域,作者通過建立一個代理來同步高度調整,需要的朋友可以參考下2016-02-02
使用JavaScript動態(tài)設置樣式實現代碼及演示動畫
使用onmouseover和onmouseout事件實現不同的效果而且是使用js動態(tài)實現,本文有利于鞏固你js與css方面的知識,感興趣的你可以了解下哦,希望本文對你有所幫助2013-01-01

