js 中事件委托


知识准备:

事件的处理流分成三个阶段:

  • 一:事件捕获阶段:当某个元素触发某个事件时,首先会触发根元素document, 然后事件将沿dom树向下传播给目标节点的每一个祖先节点,直到目标节点。
  • 二:目标阶段:到达目标元素之后,执行目标元素的事件处理函数
  • 三:事件冒泡阶段:从目标元素开始,事件将沿着DOM树向上传播,直到根节点。
Paste_Image.png

事件绑定的缺点

我们看一个demo:

<ul id="parent">
  <li>item 1</li>
  <li>item 2</li>
  <li>item 3</li>
  <li>item 4</li>
</ul>

通过绑定添加事件:

window.onload = function() {
  var parent = document.getElementById('parent');
  var children = parent.getElementsByTagName('li');
  for(var i = 0; i < children.length; i++){
    children[i].onclick = function() {
      alert(this.innerHTML);
    }
  }
}

弊端来了:如果这个ul的子元素允许无限的动态添加,就会出现问题:
1 新添加的元素不会绑定事件,所以需要每次添加li的同时添加绑定事件。
2 绑定的事件越多,性能越差。
为了解决这个问题,可以用事件代理——事件委托

事件委托

直接看demo

<ul id="parent">
  <li> item 1</li>
  <li> item 2</li>
</ul>
<scritpt>
  window.onload = function() {
    var parent = document.getElementById('parent');
    parent.addEventListener('click', function(event){
      var event = event || window.event;
      var target = event.target || event.srcElement;
      if(target.nodeName.toUpperCase() == 'LI'){
      alert(target.innerHTML);  
    }
    });
  }
</script>

好处
1 不需要为每一个元素都添加监听事件而是通过委托给父元素来处理。这样就减少了内存。性能提高了。
2 可以方便动态添加元素, 不需要再为新添加的元素重新绑定事件。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 通俗来讲就是:事件, 就是onclick,onmouseover,onmouseout,等就是事件;委托,就是让...
    leikeren阅读 523评论 0 1
  • 1.背景介绍 1.1什么是事件委托? 事件委托还有一个名字叫事件代理,JavaScript高级程序设计上讲:事件委...
    我叫于搞吧阅读 1,672评论 4 9
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,923评论 18 139
  • 事件流 IE和Netscape开发团队提出了完全相反的两种事件流的概念,事件冒泡流和事件捕获流。 事件冒泡 事件由...
    exialym阅读 984评论 0 9
  • 感,父母养育我长大,感恩他们这一路的不容易,这一路的辛酸。感恩他们教我做人的道理。 感恩命运之轮让我走了,这样场人...
    疗愈师李玉阅读 179评论 0 4