JavaScript給事件委托批量添加事件監(jiān)聽(tīng)詳細(xì)流程
1.什么是事件委托
事件委托:利用事件冒泡的特性,將本應(yīng)該注冊(cè)在子元素上的處理事件注冊(cè)在父元素上,這樣點(diǎn)擊子元素時(shí)發(fā)現(xiàn)其本身沒(méi)有相應(yīng)事件就到父元素上尋找作出相應(yīng)。這樣做的優(yōu)勢(shì)有:
- 減少DOM操作,提高性能。
- 隨時(shí)可以添加子元素,添加的子元素會(huì)自動(dòng)有相應(yīng)的處理事件。
2.事件委托的原理
事件委托是利用事件的冒泡原理來(lái)實(shí)現(xiàn)的,何為事件冒泡呢?就是事件從最深的節(jié)點(diǎn)開(kāi)始,然后逐步向上傳播事件。
舉個(gè)例子:頁(yè)面上有這么一個(gè)節(jié)點(diǎn)樹(shù),div>ul>li>a;比如給最里面的a加一個(gè)click點(diǎn)擊事件,那么這個(gè)事件就會(huì)一層一層的往外執(zhí)行,執(zhí)行順序a>li>ul>div,有這樣一個(gè)機(jī)制,那么我們給最外面的div加點(diǎn)擊事件,那么里面的ul,li,a做點(diǎn)擊事件的時(shí)候,都會(huì)冒泡到最外層的div上,所以都會(huì)觸發(fā),這就是事件委托,委托它們父級(jí)代為執(zhí)行事件。
3.事件委托的實(shí)現(xiàn)
通過(guò)一個(gè)案例來(lái)實(shí)現(xiàn)事件委托。
案例:批量添加事件監(jiān)聽(tīng)。使用JavaScript實(shí)現(xiàn):點(diǎn)擊哪個(gè)li,哪個(gè)li元素的背景變紅。
結(jié)構(gòu)層+樣式層代碼:
<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)添加點(diǎn)擊事件,內(nèi)存消耗大。
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表示用戶(hù)真正點(diǎn)擊到的那個(gè)元素。
到此這篇關(guān)于JavaScript給事件委托批量添加事件監(jiān)聽(tīng)詳細(xì)流程的文章就介紹到這了,更多相關(guān)JavaScript 事件委托內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JavaScript 事件對(duì)內(nèi)存和性能的影響
本文主要介紹了JavaScript 事件對(duì)內(nèi)存和性能的影響。具有很好的參考價(jià)值,下面跟著小編一起來(lái)看下吧2017-01-01JavaScript實(shí)現(xiàn)iframe自動(dòng)高度調(diào)整和不同主域名跨域
這篇文章主要介紹了JavaScript實(shí)現(xiàn)iframe自動(dòng)高度調(diào)整和不同主域名跨域,作者通過(guò)建立一個(gè)代理來(lái)同步高度調(diào)整,需要的朋友可以參考下2016-02-02用javascript關(guān)閉本窗口不彈出詢(xún)問(wèn)框的方法
ie中用close關(guān)閉非open打開(kāi)的窗口時(shí)回彈出一個(gè)對(duì)話(huà)框詢(xún)問(wèn)用戶(hù),怎么去掉這個(gè)框呢,在window.close之前加上window.top.opener = null就可以了2014-09-09JavaScript實(shí)現(xiàn)手寫(xiě)原生任務(wù)定時(shí)器
定時(shí)器顧名思義就是在某個(gè)特定的時(shí)間去執(zhí)行一些任務(wù),現(xiàn)代的應(yīng)用程序早已不是以前的那些由簡(jiǎn)單的增刪改查拼湊而成的程序了,高復(fù)雜性早已是標(biāo)配,而任務(wù)的定時(shí)調(diào)度與執(zhí)行也是對(duì)程序的基本要求了。本文將利用JavaScript手寫(xiě)原生任務(wù)定時(shí)器,需要的可以參考一下2022-03-03使用JavaScript動(dòng)態(tài)設(shè)置樣式實(shí)現(xiàn)代碼及演示動(dòng)畫(huà)
使用onmouseover和onmouseout事件實(shí)現(xiàn)不同的效果而且是使用js動(dòng)態(tài)實(shí)現(xiàn),本文有利于鞏固你js與css方面的知識(shí),感興趣的你可以了解下哦,希望本文對(duì)你有所幫助2013-01-01提高團(tuán)隊(duì)代碼質(zhì)量利器ESLint及Prettier詳解
這篇文章主要為大家介紹了提高團(tuán)隊(duì)代碼質(zhì)量利器ESLint及Prettier使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-11-11