关于火狐(firefox)及ie下event获取的两种方法
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了关于火狐(firefox)及ie下event获取的两种方法相关的知识,希望对你有一定的参考价值。
第一种方法:
代码如下:
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); }
代码如下:
<body onclick="a()">
简单例子如下:
代码如下:
function a(){ b(); } function b(){ alert(b === arguments.callee) alert(b.caller === a) alert(arguments.callee.caller === a) } 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常见火狐FirefoxIE浏览器兼容问题