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