欢迎您访问我爱IT技术网,今天小编为你分享的javascript教程:【关于火狐(firefox)及ie下event获取的两种方法】,下面是详细的讲解!
关于火狐(firefox)及ie下event获取的两种方法
经常有同事问我在火狐浏览器怎么获取event的方法,大多是想获取event.keyCode的功能两种方法
第一种方法:
function a(e){
e=e||window.event;
alert(e.keyCode);
}
ie浏览器如下调用
<body onclick="a()">
firefox火狐浏览器如下调用
<body onclick="a(event)">
这样就可以调用成功
这种方法在firefox需要带个参数过去,不是太好,下面介绍第二种方法
第二种方法:
function a(){
e=arguments.callee.caller.arguments[0] || window.event;
alert(e.keyCode);
}
ie和firefox下都如下调用
<body onclick="a()">
这里要解释一下arguments.callee.caller.arguments[0],
简单例子如下:
function a(){
b();
}
function b(){
alert(b===arguments.callee)
alert(b.caller===a)
alert(arguments.callee.caller===a)
}
a();
上面的这个例子将输出3个true,表明当a()调用时,函数b与函数a的关系。
arguments.callee指的就是当前的函数体
arguments.callee.caller就是当前函数的上级函数
所以当执行onclick="a()"时arguments.callee就是a(),arguments.callee.caller就是function onclick
onclick的第一个能数就是event,也就是arguments.callee.caller.arguments[0]这个。
关于关于火狐(firefox)及ie下event获取的两种方法的用户互动如下:
相关问题:javascript关于Event事件在firefox和ie中的调用问题
答:dom标准说,event对象必须作为唯一的参数传给事件处理函数。所以,在dom兼容的浏览器(Mozilla,Safari,Opera)中访问事件对象,要这么做: odiv.onclick = function () { var oevent = arguments [0];//第一个参数 ] 或者直接命名参数: odiv.onclic... >>详细
相关问题:JS window.event.target获取火狐浏览器的事件源对象吗
答:event对象的问题,ff下要传入 function testOnclick02(evt) { var e = evt | window.event; var obj = e.target; obj.value="aa"; } >>详细
相关问题:IE 与 火狐 对event keyCode操作的问题
答:document.onkeydown = function(e){ e = e ? e : window.event; var keyCode = e.which ? e.which : e.keyCode; //获取按键值 e.keyCode=9 IE浏览器 e = window.event;如果是 FF e = e lz 这我在按回车提交时试过 你说的功能 不知道能不能行 lz... >>详细
- 【firefox】firefox浏览器不支持innerText的解决
- 【Extjs】Extjs学习过程中新手容易碰到的低级错误
- 【clearInterval】js clearInterval()方法的定义
- 【ComboBox】ComboBox 和 DateField 在IE下消失的
- 【dom】javascript dom追加内容实现示例-追加内容
- 【checkbox】让checkbox不选中即将选中的checkbox
- 【Array】js中更短的 Array 类型转换-类型转换
- 【append】append和appendTo的区别以及appendChil
- 【ExtJs】ExtJs 表单提交登陆实现代码-表单提交-
- 【ajax清除浏览器缓存】Ajax清除浏览器js、css、
- 评论列表(网友评论仅供网友表达个人看法,并不表明本站同意其观点或证实其描述)
-
