javascript事件委托的用法及其好處簡析

字號(hào):


    本文為大家簡單介紹了javascript事件委托的用法及其好處,供大家參考,具體內(nèi)容如下
    事件委托:利用冒泡的原理,把事件加到父級(jí)上,觸發(fā)執(zhí)行效果,
    好處:提高性能,新添加的元素還會(huì)有之前的事件。
    event對(duì)象:事件源,不管在哪個(gè)事件中,只要你操作的那個(gè)元素就是事件源
    獲取事件源:
    IE:window.event.srcElement 
    標(biāo)準(zhǔn)下:event.target  target.nodeName來判斷是哪個(gè)標(biāo)簽
    代碼應(yīng)用如下:
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
    <style>
    </style>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title></title>
    <script type="text/javascript">
    window.onload=function ()
    {
      var oUl=document.getElementById('ul1');
      var oBtn=document.getElementById('btn1');
      var iNow=5;
      //事件源的方法依然保留父級(jí)事件!
      oUl.onmouseover=function(ev)
      {
        var ev=ev||window.event;
        var target=ev.target||ev.srcElement;
        if(target.nodeName.toLowerCase()=='li')
        {
          target.style.background='red';
        }
      }
      oUl.onmouseout=function(ev)
      {
        var ev=ev||window.event;
        var target=ev.target||ev.srcElement;
        if(target.nodeName.toLowerCase()=='li')
        {
          target.style.background='';
        }
      }
      oBtn.onclick=function()
      {
        iNow++;
        var oLi=document.createElement('li');
        oLi.innerHTML=111*iNow;
        oUl.appendChild(oLi);
      }
    }
    </script>
    </head>
    <body >
    <input type="button" value="添加" id='btn1'>
    <ul id='ul1'>
      <li>11111</li>
      <li>22222</li>
      <li>3333333</li>
      <li>44444444</li>
      <li>66666666</li>
    </ul>
    </body>
    </html>
    以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助。