我是靠谱客的博主 潇洒煎饼,最近开发中收集的这篇文章主要介绍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的用法所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

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

评论列表共有 0 条评论

立即
投稿
返回
顶部