js事件委托机制

1,什么是事件委托:通俗的讲,事件就是onclick,onmouseover,onmouseout,等就是事件,委托呢,就是让别人来做,这个事件本来是加在某些元素上的,然而你却加到别人身上来做,完成这个事件。

也就是:利用冒泡的原理,把事件加到父级上,触发执行效果。

好处呢:1,提高性能。

我们可以看一个例子:需要触发每个li来改变他们的背景颜色。


<html>
<head>
</head>
<body>
<ul id="ul">
<li>aaa</li>
<li>bbb</li>
<li>ccc</li>
</ul>

</body>
<script>

window.οnlοad=function(){
var aUL=document.getElementById("ul");
var aLI=aUL.getElementsByTagName("li");
   for(var i=0;i<aLI.length;i++){
    aLI[i].οnmοuseοver=function(){this.style.background="red";}
   aLI[i].οnmοuseοut=function(){this.style.background="";}
    }
  
}

</script>

</html>

 这样我们就可以做到li上面添加鼠标事件。

但是如果说我们可能有很多个li用for循环的话就比较影响性能。

下面我们可以用事件委托的方式来实现这样的效果。html不变

这里要用到事件源:event 对象,事件源,不管在哪个事件中,只要你操作的那个元素就是事件源。
ie:window.event.srcElement
标准下:event.target
nodeName:找到元素的标签名

<html>
<head></head>
<body>
<ul id="ul">
<li>aaa</li>
<li>bbb</li>
<li>ccc</li>
</ul>
</body>
<script>
window.οnlοad=function(){
   document.getElementById("ul").οnmοuseοver=function(event){
   
     if(event.target&&event.target.nodeName=="LI"){
         event.target.style.background="red";
      }
   }
document.getElementById("ul").οnmοuseοut=function(event){
     if(event.target&&event.target.nodeName=="LI"){
         event.target.style.background="";
      }
   }


}
</script>

</html>





评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值