js事件委託

來源:互聯網
上載者:User

標籤:over   原理   滑鼠   .net   input   document   操作   發微博   影響   

1,什麼是事件委託:通俗的講,事件就是onclick,onmouseover,onmouseout,等就是事件,委託呢,就是讓別人來做,這個事件本來是加在某些元素上的,然而你卻加到別人身上來做,完成這個事件。

也就是:利用冒泡的原理,把事件加到父級上,觸發執行效果。

好處呢:1,提高效能。

我們可以看一個例子:需要觸發每個li來改變他們的背景顏色。

<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迴圈的話就比較影響效能。

下面我們可以用事件委託的方式來實現這樣的效果。html不變

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);  }}

ok:

如同在我們用微博中,新發微博照樣有之前的滑鼠事件。

轉:http://itindex.net/detail/48661-js-%E4%BA%8B%E4%BB%B6

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.