JS事件委託

來源:互聯網
上載者:User

標籤:logs   nod   strong   冒泡   on()   function   eve   cli   沒有   

事件委託:事件就是onclick,onmouseover,onmouseout,等就是事件,委託呢,就是讓別人來做,這個事件本來是加在某些元素上的,然而你卻加到別人身上來做,完成這個事件。原理:利用冒泡原理將事件加到父級上,促發執行效果。

好處:1.提高效能

<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");  for(var i=0; i<aLi.length; i++){    aLi[i].onmouseover = function(){      this.style.background = "red";    }    aLi[i].onmouseout = function(){      this.style.background = "";    }  }}

這樣,我們可以在li上面添加滑鼠事件,但是如果有多個li用for迴圈的話比較影響效能;

事件委託方式:
window.onload = function(){  var oUl = document.getElementById("ul");  var aLi = oUl.getElementsByTagName("li");/*這裡要用到事件來源:event 對象,事件來源,不管在哪個事件中,只要你操作的那個元素就是事件來源。ie:window.event.srcElement標準下:event.targetnodeName:找到元素的標籤名*/  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 = "";    }  }}

好處2,新添加的元素還會有之前的事件。

我們還拿這個例子看,但是我們要做動態添加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);  }}



 

JS事件委託

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.