码迷,mamicode.com
首页 > 其他好文 > 详细

事件冒泡机制和事件委派 以及回调的匿名函数参数

时间:2016-04-13 20:27:11      阅读:165      评论:0      收藏:0      [点我收藏+]

标签:

1.事件冒泡机制:

事件冒泡机制也就是当一个事件绑定到一个元素上时,如果这个元素不存在或者回调函数返回ture,那么这个事件就会向上冒泡,继续绑定这个元素的父级元素直至document。(如果事件返回return false则不会冒泡)

阻止冒泡:1.事件return false ; 2.evt.stopPropagation(这个evt指此次事件,写在事件匿名回调函数的参数里)例如: $(‘li‘).click(function(evt){evt.stopPropagation()});

2.事件委托:

jQuery的on方法和delegate方法都可以给未来出现的元素绑定事件,原理就是利用事件冒泡机制

on方法和delegate方法会将【事件处理函数】绑定(委托)在需要绑定的元素的父级元素上,当其子元素触发事件时,这个事件会冒泡上来触发父元素身上的【事件处理函数】,而这个过程中会判断这个事件发生的元素是否是子元素,如果不是子元素,就不执行【事件处理函数】;

具体思路是下面这样:

// 获取父节点,并为它添加一个click事件
document.getElementById("parent-list").addEventListener("click",function(e) {
  // 检查事件源e.targe是否为Li
  if(e.target && e.target.nodeName.toUpperCase == "LI") {
    // 真正的处理过程在这里
    console.log("List item ",e.target.id.replace("post-")," was clicked!");
  }
});

e是这个事件,e.target事件发生的元素/事件源;

 

事件冒泡机制和事件委派 以及回调的匿名函数参数

标签:

原文地址:http://www.cnblogs.com/xisitan/p/5388330.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!