huanongying 2016-05-04
在 WEB 开发中有时候有这样的需求:用 JavaScript 技术,我们要在一个函数 fun 中传递一个类型为函数的参数 b ,并且函数 b 又要带参数,该怎么办呢?且看下面的例子。
<script> function func(a,b) { alert(a);//你的业务逻辑 b();//运行函数 b } var c = 5; func(1,function(c) { c=c+5 alert(c); }); </script>
运行上面的例子可以知道,第二个 alert 打印出来的是 NaN 。及无法通过上面的方法传参。这时匿名函数就派上用场了。
<script> function func(a,b) { alert(a);//你的业务逻辑 b();//运行函数 b } var c = 5; func(1,(function(c) { return function() {//返回一个匿名函数作为参数 c=c+5 alert(c); } })(c)); </script>
这时就会2个弹窗提示,第一个是1,第二个是10。也许你会感到奇怪,为什么要在匿名函数再次返回一个函数。
<script> function func(a,b) { alert(a);//你的业务逻辑 b();//运行函数 b } var c = 5; func(1,(function(c) { c=c+5 alert(c); })(c)); </script>
可以看到会有2个弹窗提示,但第一个是 10,第二个是 1 。并且用 google chrome 的开发人员工具的控制台可以看到有如下错误:
(function(c) {
c=c+5
alert(c);
})(c)
在 func 函数中,在第一个括号内,是一个匿名函数;第二个括号,表示立即执行。
关于匿名函数可以参考这里。