一、事件绑定
事件绑定又称事件委托,事件代理,可以给同一个div绑定多个事件
非IE:
element.addEventListener("click",fn,false) 事件绑定
element.removeEventLisenter("click",fn,false) 解除绑定
IE:
element.attachEvent("onclick",fn) 事件绑定
element.detachEvent("onclick",fn) 解除绑定
绑定事件兼容写法:(移除同理)
function addEvent(element,type,fn){
if(element.addEventListener){
element.addEventListener(type,fn,false)
}else if(element.attachEvent){
element.attachEvent("on"+type,fn);
}else{
target["on"+type]=fn;
}
}
二、js事件捕获和冒泡
1.什么是事件冒泡:
事件按照从最特定的事件目标到最不特定的事件目标(document对象)的顺序触发。(默认的事件处理程序,从子级到父级)
2.什么是事件捕获:
事件从最不精确的对象(document 对象)开始触发,然后到最精确(也可以在窗口级别捕获事件,不过必须由开发人员特别指定)。(捕获型事件先发生,由父级到子级)
3.事件绑定中的false,true
(1)作用:第3个参数useCapture是一个Boolean值,用来设置事件是在事件捕获时执行,还是事件冒泡时执行
(2)true:事件捕获,父级元素先触发,子级元素后触发,即div先触发,p后触发
(3)false:事件冒泡,子级元素先触发,父级元素后触发,即p先触发,div后触发。
4.阻止冒泡:
ev.cancelBubble=true;
ev.stopPropagation();
5.阻止冒泡的兼容写法:
function stopBubble(e){
if(e&&ev.stopPropagation){
e.stopPropagation();
}else{
e.cancelBubble=true;
}
}