手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >caller和callee的区别介绍及演示结果
caller和callee的区别介绍及演示结果
摘要:callercaller返回一个函数的引用,这个函数调用了当前的函数。使用这个属性要注意:1这个属性只有当函数在执行时才有用2如果在java...

caller

caller返回一个函数的引用,这个函数调用了当前的函数。

使用这个属性要注意:

1 这个属性只有当函数在执行时才有用

2 如果在javascript程序中,函数是由顶层调用的,则返回null

functionName.caller: functionName是当前正在执行的函数。

复制代码 代码如下:

var a = function() {

alert(a.caller);

}

var b = function() {

a();

}

b();

上面的代码中,b调用了a,那么a.caller返回的是b的引用,结果如下:

caller和callee的区别介绍及演示结果1

如果直接调用a(即a在任何函数中被调用,也就是顶层调用),返回null:

复制代码 代码如下:

var a = function() {

alert(a.caller);

}

var b = function() {

a();

}

//b();

a();

输出结果:

caller和callee的区别介绍及演示结果2

callee

callee放回正在执行的函数本身的引用,它是arguments的一个属性

使用callee时要注意:

1 这个属性只有在函数执行时才有效

2 它有一个length属性,可以用来获得形参的个数,因此可以用来比较形参和实参个数是否一致,即比较arguments.length是否等于arguments.callee.length

3 它可以用来递归匿名函数。

复制代码 代码如下:

var a = function() {

alert(arguments.callee);

}

var b = function() {

a();

}

b();

a在b中被调用,但是它返回了a本身的引用,结果如下:

caller和callee的区别介绍及演示结果3

【caller和callee的区别介绍及演示结果】相关文章:

无间断滚动marquee的详细用法解析

纯javascript制作日历控件

体验jQuery和AngularJS的不同点及AngularJS的迷人之处

JQuery+CSS实现图片上放置按钮的方法

JQuery中Text方法用法实例分析

jQuery实现返回顶部效果的方法

jQuery实现鼠标经过图片变亮其他变暗效果

jQuery实现延迟跳转的方法

列表内容的选择

jQuery的基本概念与高级编程

精品推荐
分类导航