//事件處理兼容各種浏覽器,采用能力檢測方法,所謂能力檢測,就是有能力就做,沒有能力就不做
//定義一個處理事件的對象,兼容各種浏覽器,dom2級事件處理和ie事件,如果這兩個事件都不兼容,就采用dom0級處理
var eventUtil ={
addEvent:function(element,type,handler){
if (element.addEventListener) {
//非IE浏覽器采用dom2級事件處理,type為事件類型如:click,handler為事件處理函數,false代表事件采用冒泡處理模型,如果是true代表 采用捕獲型處理模型
//除了netbeans采用捕獲型處理模型,其他都采用冒泡型處理模型
//如果是非IE浏覽器添加事件為:addEventListener
element.addEventListener(type,handler,false);
}else if (element.attachEvent) {
//如果為IE浏覽器,添加事件采用 attachEvent
element.attachEvent('on'+type,handler);
}else{
element['on'+type] = handler;
}
},
removeEvent:function(element,type,handler){
if (element.removeEventListener) {
//非IE浏覽器采用dom2級事件處理,type為事件類型如:click,handler為事件處理函數,false代表事件采用冒泡處理模型,如果是true代表 采用捕獲型處理模型
//除了netbeans采用捕獲型處理模型,其他都采用冒泡型處理模型
//如果是非IE浏覽器添加事件為:removeEventListener
element.removeEventListener(type,handler,false);
}else if (element.detachEvent) {
//如果為IE浏覽器,添加事件采用 detachEvent
element.detachEvent('on'+type,handler);
}else{
//dom0級事件處理,如果刪除事件采用賦值null
element['on'+type] = null;
}
},
getEvent:function(event){
//獲取事件本身
return event?event:window.event;
},
getType:function(event){
//獲取事件類型
return event.type;
},
getElement: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;
}
}
}