欢迎来到代码驿站!

JavaScript代码

当前位置:首页 > 网页前端 > JavaScript代码

关于火狐(firefox)及ie下event获取的两种方法

时间:2021-04-15 11:17:07|栏目:JavaScript代码|点击:
经常有同事问我在火狐浏览器怎么获取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]这个。

上一篇:JS回调函数原理与用法详解【附PHP回调函数】

栏    目:JavaScript代码

下一篇:javascript实现根据3原色制作颜色选择器的方法

本文标题:关于火狐(firefox)及ie下event获取的两种方法

本文地址:http://www.codeinn.net/misctech/101607.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有