美文网首页
event事件兼容

event事件兼容

作者: 5a4982b9b5fe | 来源:发表于2016-11-16 15:21 被阅读0次

window.event问题

问题说明:window.event 只能在IE下运行,而不能在Firefox下运行,这是因为Firefox的event只能在事件发生的现场使用。

解决方法:在事件发生的函数上加上event参数,在函数体内(假设形参为evt)使用 var myEvent = evt?evt:(window.event?window.event:null)

在Firefox页面调用后,其windows.event对象为undefined:

if(typeof(window.event) =='undefined')

alert('window.event is undefined.');

else

alert('window.event is defined.');

以上代码在Firefox中执行,结果为:"window.event is undefined."。IE 和 Chrome中执行结果:“window.event is defined."

1. 在函数中传递event参数

在函数中传递event参数,这样我们就可以兼容IE和FF的event的获取了,如下面的函数:

function_test(evt)

{

var src = evt.srcElement || evt.target;// 获取触发事件的源对象

alert(src.value);// 打印该对象的value属性

}

那么我们在使用的时候就应该这样:

2.在函数调用中不传递event对象

虽然在函数中没有传递参数,这个在IE下没有任何影响,因为window.event是全局对象,在什么地方都可以直接调用的,而在FF下就不行了。所以我们这里要使用另外一种方式来获取了,如下:

unction _test2()

{

varevt =window.event ||arguments.callee.caller.arguments[0];// 获取event对象

varsrc = evt.srcElement || evt.target;// 获取触发事件的源对象

variKeyCode = evt.keyCode || evt.which;//获取按钮代码

alert(src.value);// 打印该对象的value属性

if(window.navigator.userAgent.indexOf("IE")>=1){

evt.keyCode =0;

evt.returnValue=false;

}else{

evt.preventDefault();

}

}

那么,我们在使用的时候就可以想普通的函数调用一样,直接输入函数名称即可,如下:

event.srcElement问题

问题说明:IE下,even对象有srcElement属性,但是没有target属性;Firefox下,even对象有target属性,但是没有 srcElement属性。

解决方法:使用srcObj = event.srcElement ? event.srcElement : event.target;

相关文章

  • JavaScript兼容

    // 属性的兼容,使用||解决// 方法的兼容,使用if判断解决 event事件获取兼容 注意:event需要逐层...

  • event

    1. 事件对象的获取 var event = event || window.event; // 兼容写法, i...

  • event事件兼容

    window.event问题 问题说明:window.event 只能在IE下运行,而不能在Firefox下运行,...

  • 事件对象及实例

    事件对象: event兼容性: 兼容 Chrome IE系列 不兼容FireFox在FF里: ev ...

  • day11-事件

    1. 事件对象兼容(兼容IE) e = e || window.event; 2. 鼠标事件及方法; 属性名 ...

  • js Event

    1:什么是event? 2:event的兼容写法: 3: 事件源的兼容 4: 获取鼠标在可视窗口的位置 5:获取...

  • 事件目标

    1.事件目标: 事件目标 target--> event.target 真正触发事件的对象 兼容性写法 正常浏览器...

  • 兼容性(js)

    DOM节点获取 事件event获取源 3.获取ClassName问题 innertext兼容性 5.设置监听事件

  • js事件

    1.事件 (1)事件对象的兼容性写法 event对象常用属性 三个事件的重要坐标: clientX clien...

  • js网页特效(四)事件

    1.事件 (1)事件对象的兼容性写法 event对象常用属性 三个事件的重要坐标: clientX clien...

网友评论

      本文标题:event事件兼容

      本文链接:https://www.haomeiwen.com/subject/kkjrpttx.html