您的位置:首页 > Web前端 > JavaScript

javascript中callee与caller的用法和应用场景

2016-03-09 15:56 423 查看
javascript中callee和caller的用法和应用场景分析,需要的朋友可以参考下。

caller :

functionName.caller 返回调用者。

看看下面的函数,大家可以复制到VS中执行下

复制代码 代码如下:

function caller() {

if (caller.caller) {

alert(caller.caller.toString());

} else {

alert("函数直接执行");

}

}

function handleCaller() {

caller();

}

handleCaller();

caller();

大家会发现第一个alert会弹出调用caller函数的调用者handleCaller,而第二个alert由于没有在其他函数体内调用,所以caller为null,就执行了 alert("函数直接执行");

callee:

返回正被执行的 Function 对象,也就是所指定的 Function 对象的正文.

callee是arguments 的一个属性成员,它表示对函数对象本身的引用,这有利于匿名

函数的递归或者保证函数的封装性。 下面一段代码先说明callee的用法,实例代码摘自网上

复制代码 代码如下:

function calleeLengthDemo(arg1, arg2) {

alert(arguments.callee.toString());

if (arguments.length == arguments.callee.length) {

window.alert("验证形参和实参长度正确!");

return;

} else {

alert("实参长度:" + arguments.length);

alert("形参长度: " + arguments.callee.length);

}

}

calleeLengthDemo(1);

第一个消息框弹出calleeLengthDemo函数本身,这说明callee就是函数本身对象的引用。callee还有个非常有用的应用就是用来判断实际参数跟行参是否一致。上面的代码第一个消息框会弹出实际参数的长度为1,形式参数也就是函数本身的参数长度为2.

应用场景:

callee的应用场景一般用于匿名函数

大家看下下面一段代码 摘自网络

复制代码 代码如下:

var fn=function(n){

if(n>0) return n+fn(n-1);

return 0;

}

alert(fn(10))

函数内部包含了对自身的引用,函数名仅仅是一个变量名,在函数内部调用即相当于调用

一个全局变量,不能很好的体现出是调用自身,这时使用callee会是一个比较好的方法

复制代码 代码如下:

var fn=(function(n){

if(n>0) return n+arguments.callee(n-1);

return 0;

})(10);

alert(fn);

这样就让代码更加简练。又防止了全局变量的污染。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: