javascript事件模型框架

 最近一直在读《javascript高级程序设计》,也快读完了,读到事件这一章,书中提供的一个事件工具类很实用,我注释了一下,并摘记:

None.gif // eventutil.js
None.gif
var  EventUtil  =   new  Object;
ExpandedBlockStart.gifContractedBlock.gif
/**/ /* 
InBlock.gif  此方法用来给特定对象添加事件,oTarget是指定对象,sEventType是事件类型,如click、keydown等,    fnHandler是事件回调函数
InBlock.gif/*
InBlock.gifEventUtil.addEventHandler = function (oTarget, sEventType, fnHandler) {
InBlock.gif    //firefox情况下
InBlock.gif    if (oTarget.addEventListener) {
InBlock.gif        oTarget.addEventListener(sEventType, fnHandler, false);
InBlock.gif    }
InBlock.gif    //IE下
InBlock.gif    else if (oTarget.attachEvent) {
InBlock.gif        oTarget.attachEvent("on" + sEventType, fnHandler);
InBlock.gif    }
InBlock.gif    else {
InBlock.gif        oTarget["on" + sEventType] = fnHandler;
InBlock.gif    }
InBlock.gif};
InBlock.gif/* 
InBlock.gif  此方法用来移除特定对象的特定事件,oTarget是指定对象,sEventType是事件类型,如click、keydown等,fnHandler是事件回调函数
InBlock.gif/*       
InBlock.gifEventUtil.removeEventHandler = function (oTarget, sEventType, fnHandler) {
InBlock.gif    if (oTarget.removeEventListener) {
InBlock.gif        oTarget.removeEventListener(sEventType, fnHandler, false);
InBlock.gif    } else if (oTarget.detachEvent) {
InBlock.gif        oTarget.detachEvent("on" + sEventType, fnHandler);
InBlock.gif    } else { 
InBlock.gif        oTarget["on" + sEventType] = null;
InBlock.gif    }
InBlock.gif};
InBlock.gif
InBlock.gif/*
InBlock.gif 格式化事件,因为IE和其他浏览器下获取事件的方式不同并且事件的属性也不尽相同,通过此方法提供一个一致的事件
ExpandedBlockEnd.gif
*/

ExpandedBlockStart.gifContractedBlock.gifEventUtil.formatEvent 
=   function  (oEvent)  dot.gif {
InBlock.gif    
//isIE和isWin引用到一个js文件,判断浏览器和操作系统类型
ExpandedSubBlockStart.gifContractedSubBlock.gif
    if (isIE && isWin) dot.gif{
InBlock.gif        oEvent.charCode 
= (oEvent.type == "keypress"? oEvent.keyCode : 0;
InBlock.gif        
//IE只支持冒泡,不支持捕获
InBlock.gif
        oEvent.eventPhase = 2;
InBlock.gif        oEvent.isChar 
= (oEvent.charCode > 0);
InBlock.gif        oEvent.pageX 
= oEvent.clientX + document.body.scrollLeft;
InBlock.gif        oEvent.pageY 
= oEvent.clientY + document.body.scrollTop;
InBlock.gif        
//阻止事件的默认行为
ExpandedSubBlockStart.gifContractedSubBlock.gif
        oEvent.preventDefault = function () dot.gif{
InBlock.gif            
this.returnValue = false;
ExpandedSubBlockEnd.gif        }
;
InBlock.gif
InBlock.gif         
//将toElement,fromElement转化为标准的relatedTarget 
ExpandedSubBlockStart.gifContractedSubBlock.gif
        if (oEvent.type == "mouseout"dot.gif{
InBlock.gif            oEvent.relatedTarget 
= oEvent.toElement;
ExpandedSubBlockStart.gifContractedSubBlock.gif        }
 else if (oEvent.type == "mouseover"dot.gif{
InBlock.gif            oEvent.relatedTarget 
= oEvent.fromElement;
ExpandedSubBlockEnd.gif        }

InBlock.gif        
//取消冒泡      
ExpandedSubBlockStart.gifContractedSubBlock.gif
        oEvent.stopPropagation = function () dot.gif{
InBlock.gif            
this.cancelBubble = true;
ExpandedSubBlockEnd.gif        }
;
InBlock.gif
InBlock.gif        oEvent.target 
= oEvent.srcElement;
InBlock.gif        
//添加事件发生时间属性,IE没有
InBlock.gif
        oEvent.time = (new Date).getTime();
ExpandedSubBlockEnd.gif    }

InBlock.gif    
return oEvent;
ExpandedBlockEnd.gif}
;
None.gif
ExpandedBlockStart.gifContractedBlock.gifEventUtil.getEvent 
=   function ()  dot.gif {
ExpandedSubBlockStart.gifContractedSubBlock.gif    
if (window.event) dot.gif{
InBlock.gif        
//格式化IE的事件
InBlock.gif
        return this.formatEvent(window.event);
ExpandedSubBlockStart.gifContractedSubBlock.gif    }
 else dot.gif{
InBlock.gif        
return EventUtil.getEvent.caller.arguments[0];
ExpandedSubBlockEnd.gif    }

ExpandedBlockEnd.gif}
;
None.gif


附带上一个判断浏览器和系统类型的js文件,通过引入一些名字显而易见的全局变量作为判断的结果,使用时需要小心变量名称冲突:
None.gif // detect.js,同样来自《JAVASCRIPT高级程序设计》
None.gif
var  sUserAgent  =  navigator.userAgent;
None.gif
var  fAppVersion  =  parseFloat(navigator.appVersion);
None.gif
ExpandedBlockStart.gifContractedBlock.gif
function  compareVersions(sVersion1, sVersion2)  dot.gif {
InBlock.gif
InBlock.gif    
var aVersion1 = sVersion1.split(".");
InBlock.gif    
var aVersion2 = sVersion2.split(".");
InBlock.gif    
ExpandedSubBlockStart.gifContractedSubBlock.gif    
if (aVersion1.length > aVersion2.length) dot.gif{
ExpandedSubBlockStart.gifContractedSubBlock.gif        
for (var i=0; i < aVersion1.length - aVersion2.length; i++dot.gif{
InBlock.gif            aVersion2.push(
"0");
ExpandedSubBlockEnd.gif        }

ExpandedSubBlockStart.gifContractedSubBlock.gif    }
 else if (aVersion1.length < aVersion2.length) dot.gif{
ExpandedSubBlockStart.gifContractedSubBlock.gif        
for (var i=0; i < aVersion2.length - aVersion1.length; i++dot.gif{
InBlock.gif            aVersion1.push(
"0");
ExpandedSubBlockEnd.gif        }
    
ExpandedSubBlockEnd.gif    }

InBlock.gif    
ExpandedSubBlockStart.gifContractedSubBlock.gif    
for (var i=0; i < aVersion1.length; i++dot.gif{
InBlock.gif 
ExpandedSubBlockStart.gifContractedSubBlock.gif        
if (aVersion1[i] < aVersion2[i]) dot.gif{
InBlock.gif            
return -1;
ExpandedSubBlockStart.gifContractedSubBlock.gif        }
 else if (aVersion1[i] > aVersion2[i]) dot.gif{
InBlock.gif            
return 1;
ExpandedSubBlockEnd.gif        }
    
ExpandedSubBlockEnd.gif    }

InBlock.gif    
InBlock.gif    
return 0;
InBlock.gif
ExpandedBlockEnd.gif}

None.gif
None.gif
var  isOpera  =  sUserAgent.indexOf( " Opera " >   - 1 ;
None.gif
var  isMinOpera4  =  isMinOpera5  =  isMinOpera6  =  isMinOpera7  =  isMinOpera7_5  =   false ;
None.gif
ExpandedBlockStart.gifContractedBlock.gif
if  (isOpera)  dot.gif {
InBlock.gif    
var fOperaVersion;
ExpandedSubBlockStart.gifContractedSubBlock.gif    
if(navigator.appName == "Opera"dot.gif{
InBlock.gif        fOperaVersion 
= fAppVersion;
ExpandedSubBlockStart.gifContractedSubBlock.gif    }
 else dot.gif{
InBlock.gif        
var reOperaVersion = new RegExp("Opera (//d+//.//d+)");
InBlock.gif        reOperaVersion.test(sUserAgent);
InBlock.gif        fOperaVersion 
= parseFloat(RegExp["$1"]);
ExpandedSubBlockEnd.gif    }

InBlock.gif
InBlock.gif    isMinOpera4 
= fOperaVersion >= 4;
InBlock.gif    isMinOpera5 
= fOperaVersion >= 5;
InBlock.gif    isMinOpera6 
= fOperaVersion >= 6;
InBlock.gif    isMinOpera7 
= fOperaVersion >= 7;
InBlock.gif    isMinOpera7_5 
= fOperaVersion >= 7.5;
ExpandedBlockEnd.gif}

None.gif
None.gif
var  isKHTML  =  sUserAgent.indexOf( " KHTML " >   - 1  
None.gif              
||  sUserAgent.indexOf( " Konqueror " >   - 1  
None.gif              
||  sUserAgent.indexOf( " AppleWebKit " >   - 1
None.gif              
None.gif
var  isMinSafari1  =  isMinSafari1_2  =   false ;
None.gif
var  isMinKonq2_2  =  isMinKonq3  =  isMinKonq3_1  =  isMinKonq3_2  =   false ;
None.gif
ExpandedBlockStart.gifContractedBlock.gif
if  (isKHTML)  dot.gif {
InBlock.gif    isSafari 
= sUserAgent.indexOf("AppleWebKit"> -1;
InBlock.gif    isKonq 
= sUserAgent.indexOf("Konqueror"> -1;
InBlock.gif
ExpandedSubBlockStart.gifContractedSubBlock.gif    
if (isSafari) dot.gif{
InBlock.gif        
var reAppleWebKit = new RegExp("AppleWebKit///(//d+(?://.//d*)?)");
InBlock.gif        reAppleWebKit.test(sUserAgent);
InBlock.gif        
var fAppleWebKitVersion = parseFloat(RegExp["$1"]);
InBlock.gif
InBlock.gif        isMinSafari1 
= fAppleWebKitVersion >= 85;
InBlock.gif        isMinSafari1_2 
= fAppleWebKitVersion >= 124;
ExpandedSubBlockStart.gifContractedSubBlock.gif    }
 else if (isKonq) dot.gif{
InBlock.gif
InBlock.gif        
var reKonq = new RegExp("Konqueror///(//d+(?://.//d+(?://.//d)?)?)");
InBlock.gif        reKonq.test(sUserAgent);
InBlock.gif        isMinKonq2_2 
= compareVersions(RegExp["$1"], "2.2">= 0;
InBlock.gif        isMinKonq3 
= compareVersions(RegExp["$1"], "3.0">= 0;
InBlock.gif        isMinKonq3_1 
= compareVersions(RegExp["$1"], "3.1">= 0;
InBlock.gif        isMinKonq3_2 
= compareVersions(RegExp["$1"], "3.2">= 0;
ExpandedSubBlockEnd.gif    }
 
InBlock.gif    
ExpandedBlockEnd.gif}

None.gif
None.gif
var  isIE  =  sUserAgent.indexOf( " compatible " >   - 1  
None.gif           
&&  sUserAgent.indexOf( " MSIE " >   - 1
None.gif           
&&   ! isOpera;
None.gif           
None.gif
var  isMinIE4  =  isMinIE5  =  isMinIE5_5  =  isMinIE6  =   false ;
None.gif
ExpandedBlockStart.gifContractedBlock.gif
if  (isIE)  dot.gif {
InBlock.gif    
var reIE = new RegExp("MSIE (//d+//.//d+);
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值