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

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

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

匿名函数的递归:

var num = (function(num){
      if(num<=1){
          return 1;
      }else{
          return num*arguments.callee(num-1);
      }
 })(5);
  alert(num); //结果为120

红绿灯异步输出

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内容请搜索靠谱客的其他文章。

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

评论列表共有 0 条评论

立即
投稿
返回
顶部