js事件委託是什麼?使用事件委託又有哪些好處? 相信很多的朋友或許會有這樣的疑問,那麼,接下來的這篇文章就給大家來說一說關於js事件委託的概念以及使用js事件委託的好處。
1、什麼是js事件委託?
利用事件冒泡處理動態元素事件綁定的方法,專業術語叫事件委託,簡單點來說就是給父元素綁定事件,用來監聽子元素的冒泡事件,並找到是哪個子元素的事件,更加通俗一點那就是讓別人來做,這個事件本來是加在某些元素上的,然而你卻加到別人身上來做,完成這個事件。 (事件有哪些?請看:JavaScript中文參考手冊)
例如下面這個範例:原生js實作事件委託
<!DOCTYPE html> <html> <head> <title>事件委托测试</title> </head> <body> <style type="text/css"> *{margin: 0;padding: 0;} a{text-decoration: none;} ul,li{list-style: none;} div{display: block;width: 500px;padding: 200px 0 0 200px;} div ul li{display: block;width: 100%;text-align: center;height: 35px;line-height: 35px;} div ul li:nth-child(2n){background: #f00;} </style> <div> <ul> <li><a>测试1</a></li> <li><a>测试2</a></li> <li><a>测试3</a></li> <li><a>测试4</a></li> <li><a>测试5</a></li> <li><a>测试6</a></li> <li><a>测试7</a></li> <li><a>测试8</a></li> </ul> </div> <script type="text/javascript"> document.getElementsByTagName("ul")[0].addEventListener('click',function(e){ alert("点击的内容是:"+e.target.innerHTML); }); </script> </body> </html>
注意: js實作事件委託有三個步驟:
第一步:給父元素綁定事件
給元素ul新增綁定事件,透過addEventListener為點擊事件click新增綁定
第二步:監聽子元素的冒泡事件
這裡預設是冒泡,點選子元素li會向上冒泡
#第三步:找到是哪個子元素的事件
透過匿名回呼函數的參數e用來接收事件對象,透過target取得觸發事件的目標
2、js事件委託的好處:
事件委託的好處1:事件委託技術可以避免對每個字元素添加事件監聽器,減少操作DOM節點的次數,從而減少瀏覽器的重繪和重排,提高程式碼的效能。
我們可以看一個例子:我們要做動態的新增li。點擊button動態新增li
<input type="button" id="btn" /><ul id="ul"> <li>aaaaaaaa</li> <li>bbbbbbbb</li> <li>cccccccc</li></ul>
不用事件委託我們會這樣做:
window.onload = function(){ var oUl = document.getElementById("ul"); var aLi = oUl.getElementsByTagName("li"); var oBtn = document.getElementById("btn"); var iNow = 4; for(var i=0; i<aLi.length; i++){ aLi[i].onmouseover = function(){ this.style.background = "red"; } aLi[i].onmouseout = function(){ this.style.background = ""; } } oBtn.onclick = function(){ iNow ++; var oLi = document.createElement("li"); oLi.innerHTML = 1111 *iNow; oUl.appendChild(oLi); } }
這樣做我們可以看到點擊按鈕新加的li上面沒有滑鼠移入事件來改變他們的背景顏色。
因為點選新增的時候for迴圈已經執行完畢。
那麼我們用事件委託的方式來做。就是html不變
window.onload = function(){ var oUl = document.getElementById("ul"); var aLi = oUl.getElementsByTagName("li"); var oBtn = document.getElementById("btn"); var iNow = 4; oUl.onmouseover = function(ev){ var ev = ev || window.event; var target = ev.target || ev.srcElement; //alert(target.innerHTML); if(target.nodeName.toLowerCase() == "li"){ target.style.background = "red"; } } oUl.onmouseout = function(ev){ var ev = ev || window.event; var target = ev.target || ev.srcElement; //alert(target.innerHTML); if(target.nodeName.toLowerCase() == "li"){ target.style.background = ""; } } oBtn.onclick = function(){ iNow ++; var oLi = document.createElement("li"); oLi.innerHTML = 1111 *iNow; oUl.appendChild(oLi); } }
事件委託的好處2:使用事件委託,只有父元素與DOM存在交互,其他的操作都是在JS虛擬記憶體中完成的,這樣就大大提高了性能。
相關推薦:
#javascript事件委託和jQuery事件綁定on、off 和one
以上是js事件委託是什麼?使用js事件委託的好處有哪些?的詳細內容。更多資訊請關注PHP中文網其他相關文章!