1.事件代理(事件委托)
定义:当我们要对多个元素添加事件时,可以将事件添加给它们的父节点,而将事件委托给父节点来触发函数。如以上代码,要给li下的a注册事件,我们一般会将所有的a都注册事件,这样就非常麻烦。##从最底层的标签开始找,所以找到的是a,不是li.我们可以使用更简单的事件代理机制,当事件触发时,事件会被抛到上层父节点,我们通过检查事件目标对象target,来判断并获取事件源li。##事件监听:通过addEventListener注册事件监听函数
// 获取父节点,并为它添加一个click事件var list=document.getElementById("parent-list");list.addEventListener("click",function(e) {// 检查事件源e.target是否为A//e.target意思是表示获取事件目标console.log(e.target.tagName);//,如果e.target存在且e.target的标签名是A(a要大写)if(e.target && e.target.tagName == "A") {// 真正的处理过程在这里alert("注册成功");}});
jquery中使用事件代理:
$("#parent-list").on("click","a",function(){alert("注册成功");}
2.事件处理流程
事件处理流程有3个阶段:a.事件捕获阶段当某个元素触发事件时,顶层对象document会发出一个事件流,沿着DOM节点树流向并直到到达事件真正发生的目标元素。事件捕获阶段,事件监听函数是不会触发的。b.事件目标阶段
当到达目标元素以后,执行目标元素触发该事件相应的执行函数,如果没有绑定事件监听函数,那就不执行。c.事件冒泡阶段
从目标元素开始,一直往顶层传播,途中如果有节点绑定了相应的事件处理函数,都会被执行。如果要阻止事件冒泡,chrome和火狐使用e.stopPropagation() ,IE则使用window.event.cancelBubble = true。js代码执行阻止事件冒泡,兼容ie火狐。function myFn(){ window.event ? window.event.cancelBubble = true : e.stopPropagation();}##在ie浏览器中,window.event是全局变量,在非ie中,就需要自己传入一个参数(比如e)来获取event啦,所以就有了var e = e||window.event,同时兼容IE与谷歌. 3.阻止浏览器默认行为谷歌的方法:e.preventDefault()IE的方法:window.event.returnValue=false ;function stopFn(){window.event ?window.event.returnValue=false : e.preventDefault() ;}
4.return false
javascript中return false只能阻止默认行为,不会阻止事件冒泡。在jquery中,return false既可以阻止默认行为,又可以阻止事件冒泡。