递归函数实在一个函数通过名字调用自身的情况下构成的。
1 window.onload = function() {
2 var a = factorial;
3 factorial = null;
4 alert(a(4));
5 };
6
7 /**
8 * 叠乘
9 * @param {叠乘的基数} num n
10 * @return {叠乘结果} n*(n-1)*(n-2)*...*1
11 */
12 var factorial = (function f(num){
13 if (num <= 1) {
14 return 1;
15 }else{
16 return num * f(num - 1);
17 }
18 });
这里使用的是命名函数表达式的方法实现递归,将这个函数赋值给 factorial 。这样即使在使用过程中对变量进行修改,也不会影响已赋值的递归函数进行调用,保证了代码的安全性。这种方式在严格模式和非严格模式下都适用。