function factorial(num){
if(num <= 1){
return 1;
}else{
return num * factorial(num - 1);
}
}
console.log(factorial(5));
一开始的常规写法,但是有个问题是内部调用自身是使用函数名字,如果在将factorial赋值到一个变量之后,尽管还是调用原factorial函数,但不是期望的调用函数自身的写法了
此时假如用一个变量赋值当期函数,再把递归函数变为null,后面再用赋值函数时就找不到这个值了
function factorial(num){
if(num <= 1){
return 1;
}else{
return num * factorial(num - 1);
}
}
var another = factorial;
console.log('another = ',another);
factorial = null;
console.log('factorial = ',factorial);
console.log(another(5));
缺点:
a.严格模式下,不能通过脚本访问arguments.callee,访问这个属性会导致错误;
b.arguments是庞大且变化的,每次访问需要消耗大量性能;
2.命名函数表达式
var factorial = (function f(num){
if(num <= 1){
return 1;
}else{
return num * f(num - 1);
}
});
var another = factorial;
factorial = null;
console.log(another(5)); // 120
这种方式在严格模式和非严格模式下都行得通