JS中的事件委托實例淺析
本文實例講述了JS中的事件委托。分享給大家供大家參考,具體如下:
事件委托(也叫事件代理),其實這個問題也簡單,要想弄明白事件委托,我們先要把事件冒泡的機制搞清楚。舉個事件冒泡的例子:
<ul> <li>點擊</li> </ul> <script> var ul=document.getElementsByTagName('ul')[0]; var li=document.getElementsByTagName('li')[0]; ul.addEventListener('click', function(){ alert('我是ul,我被點擊了'); }, false); li.addEventListener('click', function(){ alert('我是li,我被點擊了'); }, false); </script>
在這段代碼中,當我們點擊li的時候出發(fā)了li的click事件,但是在這時,ul的click事件也被觸發(fā)了,這就是事件的冒泡。搞明白這個之后,我們就可以來說事件委托了,既然事件能從子元素(li)冒泡的父元素(ul)身上,那么我們就可以給ul自己加一個click事件,把所有l(wèi)i的事件都委托給了我們的父級(ul)身上,可能到這里有些朋友還是不明白這個事件委托到底有什么用,我們在舉一個事件委托的實例來說明一下:
<ul> <li>點擊1</li> <li>點擊2</li> <li>點擊3</li> <li>點擊4</li> <li>點擊5</li> </ul> <script> //使用事件委托的代碼 var ul=document.getElementsByTagName('ul')[0]; ul.addEventListener('click', function(e){ alert(e.target.innerHTML); }, false); //不使用事件委托,循環(huán)給li添加click事件 var li=document.getElementsByTagName('li') for(var i=0;i<li.length;i++){ li[i].onclick=function(){ alert(this.innerHTML); } } </script>
我們以上代碼把事件委托給了ul,只給ul增加點擊事件,在瀏覽器中運行點擊對應(yīng)的li會彈出li對應(yīng)的innerHTML
,這個function(e){};
中的e這個參數(shù)實際上就是當前我們點擊li時,系統(tǒng)傳給我們的一些事件信息,e.target
實際上指的就是當前我們點擊的這個li,在這里我們每次彈出的都是當前點擊對象的innerHTML
,這就是一個簡單的事件委托的案例。
而事件委托對于我們優(yōu)化代碼意義是非常大的,我們都知道,頻繁的dom操作是非常耗費性能的,現(xiàn)在ul里邊是5個li,我們假如不用事件委托實現(xiàn)上面代碼所作的事情,就需要用for循環(huán),給每個li都寫一個click事件,這樣一來dom操作就比較多了,如果是10個li呢,100個甚至更多呢,單不說dom操作影響的性能,li過多for循環(huán)自身就會占用大量的事件。如果利用事件委托,既避免了for循環(huán)耗費的性能,又省去了繁多的dom操作耗費的性能。
PS:關(guān)于javascript事件說明可參考本站javascript事件與功能說明大全:http://tools.jb51.net/table/javascript_event
更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《JavaScript頁面元素操作技巧總結(jié)》、《JavaScript操作DOM技巧總結(jié)》、《JavaScript查找算法技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript錯誤與調(diào)試技巧總結(jié)》
希望本文所述對大家JavaScript程序設(shè)計有所幫助。
相關(guān)文章
JavaScript常用的返回,自動跳轉(zhuǎn),刷新,關(guān)閉語句匯總
這篇文章主要介紹了JavaScript常用的返回,自動跳轉(zhuǎn),刷新,關(guān)閉語句,實例匯總了常用的javascript技巧,非常具有實用價值,需要的朋友可以參考下2015-01-01微信小程序 wx.getUserInfo引導(dǎo)用戶授權(quán)問題實例分析
這篇文章主要介紹了微信小程序 wx.getUserInfo引導(dǎo)用戶授權(quán)問題,結(jié)合實例形式分析了微信小程序使用wx.getUserInfo引導(dǎo)用戶授權(quán)問題的具體操作步驟與實現(xiàn)方法,需要的朋友可以參考下2020-03-03js前臺分頁顯示后端JAVA數(shù)據(jù)響應(yīng)
js前臺分頁顯示使用jquery1.8.7框架,本文目的主要給那些剛?cè)胄熊浖_發(fā),喜歡這也看看,程序需要有投入才有收獲感興趣的你可不要錯過了哈,希望可以幫助到你2013-03-03無限循環(huán)輪播圖之運動框架(原生JS實現(xiàn))
下面小編就為大家?guī)硪黄獰o限循環(huán)輪播圖之運動框架(原生JS實現(xiàn))。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-10-10JavaScript原型對象、構(gòu)造函數(shù)和實例對象功能與用法詳解
這篇文章主要介紹了JavaScript原型對象、構(gòu)造函數(shù)和實例對象功能與用法,結(jié)合實例形式分析了javascript面向?qū)ο笙嚓P(guān)原型對象、構(gòu)造函數(shù)及實例對象的概念、功能與相關(guān)使用技巧,需要的朋友可以參考下2018-08-08