码迷,mamicode.com
首页 > Windows程序 > 详细

小议window.event || ev

时间:2015-05-15 15:16:03      阅读:175      评论:0      收藏:0      [点我收藏+]

标签:

以前做项目时就遇到这个问题,但是太懒没有总结,今天来总结一下

 

onclick="alert(arguments.callee)"这句随便放在某个元素中,试试不同的浏览器会有弹出什么?

结果:

IE7和IE8-------> function onclick(){alert(arguments.callee)}不得不说这俩老小子跟不上时代的步伐,只能靠程序员拖着走.IE6已经被微软放弃,听说阿里都不用再兼容到IE6

IE9、firefox、chrome------>function onclick(event){alert(arguments.callee)}

 

可能会有人不知道arguments,先来说说这个对象,没错,是对象,一个类似数组的对象

很多js库都利用了arguments对象,所以agruments对象对于javascript程序员来说是必需熟悉的。

alert(arguments instanceof Array);//返回false

alert(typeof(arguments));//返回object

 

 作用之一   可以创建一个灵活的函数

当函数参数不确定时,but通过arguments就可以方面的知道函数参数的具体个数

注意:arguments是实参的副本,也就是说与形参无关!

 

arguments.callee 返回正在执行的函数本身的引用,怎么理解呢,对函数本身的引用,对,就是这样,是不是很熟悉,递归呀,递归不就是引用了自身,callee方法可以完美实现递归!

还有一个caller方法,在这儿就不说了

 

 回到刚开始的地方

因为存在兼容性问题,所以我们经常需要这样写 

function Function(ev){
     var event = window.event||ev;
}

  另外,当一个函数没有实参时,arguemgns对象的第一个值就是event对象。

小议window.event || ev

标签:

原文地址:http://www.cnblogs.com/jianjianwoshi/p/4505414.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!