在程序设计中我们经常会用到递归函数,而对于递归函数的算法大家应该都很熟悉。下面以求1到N的和为例子,跟大家分享一下使用arguments.callee实现匿名函数的递归。
常规方法如下:
1 |
var fn = function (n){ |
2 |
if (n>=1) return n+fn(n-1); |
3 |
return 0; |
4 |
} |
5 |
alert(fn(10)); //55 |
上面的是普通做法,但在复杂的程序设计中我们或许只要求调用一次该函数,在要求尽量少的函数名定义时,匿名函数是我们的比较理想的选择。但匿名函数如何递归呢?这里我们可以使用arguments.callee来实现。arguments.callee指代的是当前执行的函数的一个引用。
1 |
var b=( function (n){ |
2 |
if (n>=1){ |
3 |
return n+arguments.callee(n-1); |
4 |
return 0; |
5 |
} |
6 |
})(10); |
7 |
alert(b); |
看到没?很方便的就实现了匿名函数的递归运算。
(非常感謝原文作者,出处:http://my.oschina.net/bojinzhu/blog/52389 紫寒1120)