递归
递归函数是在函数通过调用自身的情况下构成的
1 function factorial(num){ 2 if (num <=1){ 3 return 1; 4 } else { 5 return num * factorial(num-1); 6 } 7 }
这是一个经典的递归阶乘函数,但是下面的代码会让它出错
1 var anotherFactorial = factorial; 2 factorial = null; 3 console.log(anotherFactorial(4));//factorial is not a function
在执行anotherFactorial()函数时,factorial已经不是函数了
arguments.callee是一个指向正在执行的函数的指针,因此何以用它来实现对函数的递归调用
1 function factorial(num){ 2 if (num <=1){ 3 return 1; 4 } else { 5 return num * arguments.callee(num-1); 6 } 7 }
但是在严格模式下,不能通过脚本访问arguments.callee,访问这个属性会导致错误。不过,可以使用命名函数表达式达成相同的结果
1 var factorial = (function f(num){ 2 if (num <= 1){ 3 return 1; 4 } else { 5 return num * f(num -1); 6 } 7 }); 8 9 var anotherFactorial = factorial; 10 factorial = null; 11 console.log(anotherFactorial(4)); //24
时间: 2024-10-16 14:26:36