递归函数实在一个函数通过名字调用自身的情况下构成的。
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 。这样即使在使用过程中对变量进行修改,也不会影响已赋值的递归函数进行调用,保证了代码的安全性。这种方式在严格模式和非严格模式下都适用。