我是靠谱客的博主 潇洒煎饼,这篇文章主要介绍arguments.callee的用法,现在分享给大家,希望可以做个参考。

argument为函数内部对象,包含传入函数的所有参数,arguments.callee代表函数名,多用于递归调用,防止函数执行与函数名紧紧耦合的现象,对于没有函数名的匿名函数也非常起作用。举例如下:

复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
function factorial(num){ if(num<=1){ return 1; }else{ return num*arguments.callee(num-1); //arguments.callee代表factorial } } var trueFactorial = factorial; factorial = function(){ return 0; } alert(trueFactorial(5)); //结果为120,因为js中函数没有重载,所以如果递归调用时使用函数名,则执行最后一个该函数名的函数,即返回0 alert(factorial(5));//结果为0

匿名函数的递归:

复制代码
1
2
3
4
5
6
7
8
9
var num = (function(num){ if(num<=1){ return 1; }else{ return num*arguments.callee(num-1); } })(5); alert(num); //结果为120

红绿灯异步输出

复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
function showRed(fn1, fn2){ var f = arguments.callee; //函数本身 //arguments.callee 执行该函数的上下文执行环境,指向调用他的对象 setTimeout(function(){ console.log("红灯"); fn1(fn2, f); }, 2000); } function showYellow(fn1, fn2){ var f = arguments.callee; setTimeout(function(){ console.log("黄灯"); fn1(fn2, f); }, 1000); } function showGreen(fn1, fn2){ var f = arguments.callee; setTimeout(function(){ console.log("绿灯"); fn1(fn2, f); }, 3000); } showRed(showYellow, showGreen);

最后

以上就是潇洒煎饼最近收集整理的关于arguments.callee的用法的全部内容,更多相关arguments.callee内容请搜索靠谱客的其他文章。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(73)

评论列表共有 0 条评论

立即
投稿
返回
顶部