首页 > 其他 > 详细

事件代理与事件处理流程

时间:2017-08-28 09:15:33      阅读:263      评论:0      收藏:0      [点我收藏+]

1.事件代理(事件委托)
定义:当我们要对多个元素添加事件时,可以将事件添加给它们的父节点,而将事件委托给父节点来触发函数。
<ul id="parent-list">
<li id="post-1"><a href="#">我是第1</a></li>
<li id="post-2"><a href="#">我是第2</a></li>
<li id="post-3"><a href="#">我是第3</a></li>
<li id="post-4"><a href="#">我是第4</a></li>
<li id="post-5"><a href="#">我是第5</a></li>
<li id="post-6"><a href="#">我是第6</a></li>
</ul>
如以上代码,要给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既可以阻止默认行为,又可以阻止事件冒泡。

事件代理与事件处理流程

原文:http://www.cnblogs.com/sharkJan/p/7442354.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!