获取Event

IE浏览器中可以直接用 window.event或event获得event对象(建议最后是用window.event 这样可防止在作用域发生问题)

DOM标准的浏览器中不能直接使用window.event和 event对象,系统把event对像以函数参数方式传给触发事件的调用函数。第一个参数就是event对像

如:

document.οnclick=function(evt){
   alert(evt)//evt 就是传回来event对像
}

 

兼容获取event对像的简单写法

 

document.οnclick=function(evt){
evt  =  evt||window.event;//兼容获取event对像的简单写法
alert(evt);
}

下面提供同时兼容IE和Firefox的获得event对象的方法,在需要用到event对象的地方,调用该方法即可.

function getEvent() //同时兼容ie和ff的写法 
    {  
        if(document.all)  return window.event;    
        func=getEvent.caller;        
        while(func!=null){  
            var arg0=func.arguments[0]; 
            if(arg0) 
            { 
              if((arg0.constructor==Event || arg0.constructor ==MouseEvent) || (typeof(arg0)=="object" && arg0.preventDefault && arg0.stopPropagation)) 
              {  
              return arg0; 
              } 
            } 
            func=func.caller; 
        } 
        return null; 
    } 
//如调用:
document.οnclick=function(){
var evt=getEvent();
alert(evt);
}


 

转载于:https://www.cnblogs.com/jsk540/archive/2010/09/25/1834836.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值