事件:
DOM事件:firefox, opera, safari 和 chrome
专有事件:ie
DOM事件流:
document -> html -> body (捕获阶段)-> div(目标,事件发生) ->body -> html ->document(冒泡阶段)
包括HTML事件处理程序,DOM0级事件处理程序,DOM2级事件处理程序
DOM2级事件处理程序,两个方法addEventListener(事件名,事件处理程序函数,布尔值)和removeEventListener()
布尔值的参数:true->在捕获阶段调用事件处理程序;false->在冒泡阶段调用事件处理程序
例如:
addEventListener("click",function(){alert(this.id)},false);this->元素的作用域
IE事件:
两个方法attachEvent(事件处理程序名称,事件处理程序函数)和detachEvent()
例如:attachEvent("onclick",function(){alert(this === window)});//true,事件处理程序在全局作用域
-------------------------------------------------------------
跨浏览器的事件处理:
var EventUtil = {
addHandler: function(element, type, handler){
if(element.addEventListener){
element.addEventListener(type,handler,false);//dom2级
}else if(element.attachEvent){
element.attachEvent("on" + type,handler);//ie
}else{
element["on" + type] = handler;
}
},
removerHandler: function(element, type, handler){
if(element.removeEventListener){
element.removeEventListener(type,handler,false);
}else if(element.detachEvent){
element.detachEvent("on" + type, handler);
}else{
element["on" + type] = null;
}
},
getEvent: function(event){
return event ? event : window.event;
},
getTarget: function(event){
return event.target || event.srcElement;
},
preventDefault: function(event){
if(event.preventDefault){
event.preventDefault();
}else{
event.returnValue = false;
}
},//取消事件的默认行为
stopPropagation: function(event){
if(event.stopPropagation){
event.stopPropagation();
}else{
event.cancelBubble = true;
}
},//取消事件的进一步冒泡
getRelatedTarget: function(event){
if(event.relatedTarget){
return event.relatedTarget;
}else if(event.toElement){
return event.toElement;
}else if(event.fromElement){
return event.fromElement;
}else{
return null;
}
},//取得相关元素的信息,只针对mouseover和mouseout
getButton: function(event){
if(document.implementation.hasFeature("MouseEvents","2.0")){
return event.button;
}else{
switch(event.button){
case 0:
case 1:
case 3:
case 5:
case 7:
return 0;
case 2:
case 6:
return 2;
case 4:
return 1;
}
}
}//获得点击鼠标的情况
};
分享到:
相关推荐
使用JavaScript事件综合查询,js事件大全
1.实现JavaScript事件注册;...2.实现JavaScript事件处理函数; 3.实现JavaScript鼠标和键盘事件; 4.实现JavaScript表单相关事件; 5.实现JavaScript字幕滚动事件; 6.实现JavaScript编辑事件;
javascript事件冒泡,事件捕获和事件委托详解 1、事件冒泡:在javascript事件传播过程中,当事件在一个元素上出发之后,事件会逐级传播给先辈元素,直到document为止,有的浏览器可能到window为止。并不是所有的...
JavaScript事件派发器,对单页交互应用中组件通信十分有用。个人原创,发现bug可向我github中提issue~
Js事件大全
第3章+JavaScript事件处理.pdf
Js事件大全 1.一般事件... 2 2.页面相关事件... 2 3.表单相关事件... 3 4.滚动字幕事件... 3 5.编辑事件... 3 6.数据绑定... 4
asp.net中TextBox获得焦点和失去焦点——客户端JavaScript事件 自己亲手做的 ,虽然很简单,但是很实用
[js]javascript事件集合(包有触发事件)终版.pdf
JavaScript事件学习小结(五)js中事件类型之鼠标事件 //www.jb51.net/article/86259.htm JavaScript事件学习小结(一)事件流 //www.jb51.net/article/86261.htm javaScript事件学习小结(四)event的公共成员...
JavaScript事件学习小结(五)js中事件类型之鼠标事件 //www.jb51.net/article/86259.htm JavaScript事件学习小结(一)事件流 //www.jb51.net/article/86261.htm javaScript事件学习小结(四)event的公共成员...
全面,直观javascript的事件
如何给javascript js事件传递参数.zip
javascript的事件大全,很详细的介绍
系统介绍了javascript事件,包括平常理解不透彻的捕获,冒泡等机制,值得一看
JavaScript事件学习小结(五)js中事件类型之鼠标事件 //www.jb51.net/article/86259.htm JavaScript事件学习小结(一)事件流 //www.jb51.net/article/86261.htm javaScript事件学习小结(四)event的公共成员...
js事件大全js事件大全js事件大全js事件大全js事件大全js事件大全js事件大全js事件大全js事件大全js事件大全js事件大全js事件大全js事件大全js事件大全
eventdispatcher.js, 自定义对象的JavaScript事件 eventdispatcher.js 自定义对象的JavaScript事件用法[removed][removed][removed]
[js]javascript事件集合(包有触发事件).pdf
[js]javascript事件集合(包有触发事件)[参考].pdf