javascript中arguments,callee,caller详解

前端之家收集整理的这篇文章主要介绍了javascript中arguments,callee,caller详解前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

arguments是什么?

@H_403_3@

arguments是函数调用时,创建的一个类似的数组但又不是数组的对象,并且它存储的是实际传递给函数的参数,并不局限于函数声明的参数列表哦。@H_403_3@

尼玛,什么意思?@H_403_3@

写个demo看看,代码见下@H_403_3@

arguments <Meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>

运行该代码,通过chrome调试器,可得下图@H_403_3@

@H_403_3@@H_403_3@

我利用instanceof判断arguments,从打印的效果看,arguments是一个对象。@H_403_3@

然后展开打印出的arguments,可以从上图得知,它里面包括了许多属性,callee也在内。@H_403_3@

接下来,我们修改上面的代码,在调用obj函数时,给它传递参数,但obj函数是没有参数的。@H_403_3@

具体代码见下@H_403_3@

arguments <Meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>

通过chrome调试器,可得下图@H_403_3@

@H_403_3@@H_403_3@

大家可以看见,arguments包含了三个我们给它传递的参数”monkey”,”love”,24。@H_403_3@

所以说,为什么arguments是存储的实际传递给函数的参数呢,而不是函数声明的参数。@H_403_3@

callee是什么?

@H_403_3@

callee是arguments对象的一个成员,它的值为“正被执行的Function对象”。@H_403_3@

什么意思呢?@H_403_3@

我们写个demo,看看输出结果就知道啦。@H_403_3@

代码和结果图见下@H_403_3@

callee <Meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>

从上面的图片可知,arguments.callee是指向参数arguments对象的函数,在这里就是obj咯。@H_403_3@

@H_403_3@@H_403_3@

caller是什么?

@H_403_3@

caller是函数对象的一个属性,该属性保存着调用当前函数函数。@H_403_3@

注意,是调用。不仅仅包含闭包哦。如果没有父函数,则为null。@H_403_3@

还是老样子,我们一直来写个demo看看。@H_403_3@

代码如下:@H_403_3@

caller <Meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>

打开chrome调试器,可得下效果图@H_403_3@

@H_403_3@@H_403_3@

结合代码和上图理解,这下理解了caller了么?@H_403_3@

猜你在找的JavaScript相关文章