手机
当前位置:查字典教程网 >编程开发 >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的区别介绍及演示结果】相关文章:

纯javascript制作日历控件

JavaScript中的异常处理方法介绍

JavaScript实现广告的关闭与显示效果实例

JQuery中Text方法用法实例分析

JavaScript中继承用法实例分析

jQuery实现延迟跳转的方法

JS动态增删表格行的方法

jQuery的基本概念与高级编程

采用CSS和JS,刚好我最近有个站点要用到下拉菜单!

多附件上传组件演示

精品推荐
分类导航