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

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事件发生的元素/事件源;

 

posted @ 2016-04-13 18:40  刺蛇笑眯眯  阅读(441)  评论(0编辑  收藏  举报