封裝常用的事件添加,移除以及其他事件方法兼容瀏覽器
//事件處理兼容各種瀏覽器,采用能力檢測方法,所謂能力檢測,就是有能力就做,沒有能力就不做
?
?//定義一個處理事件的對象,兼容各種瀏覽器,dom2級事件處理和ie事件,如果這兩個事件都不兼容,就采用dom0級處理
?var ?eventUtil ={
? ? ? ?addEvent:function(element,type,handler){
? ? ? ? ? ? if (element.addEventListener) {
? ? ? ? ? ? //非IE瀏覽器采用dom2級事件處理,type為事件類型如:click,handler為事件處理函數(shù),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為事件處理函數(shù),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;
? ? ? ? ? }
? ? ? ?}
?}
2015-12-22
贊一個