循环中的闭包 一个常见的错误出如今循环中使用闭包,假设咱们须要在每次循环中调用循环序号闭包
for(var i = 0; i < 10; i++) { setTimeout(function() { console.log(i); }, 1000); }
上面的代码不会输出数字 0 到 9,而是会输出数字 10 十次。函数
当 console.log 被调用的时候,匿名函数保持对外部变量 i 的引用,此时 for循环已经结束, i 的值被修改为了 10.post
为了获得想要的结果,须要在每次循环中建立变量 i 的拷贝。code
避免引用错误get
为了正确的得到循环序号,最好使用 匿名包裹器(译者注:其实就是咱们一般说的自执行匿名函数)。io
for(var i = 0; i < 10; i++) { (function(e) { setTimeout(function() { console.log(e); }, 1000); })(i); }
外部的匿名函数会当即执行,并把 i 做为它的参数,此时函数内 e 变量就拥有了 i 的一个拷贝。console
当传递给 setTimeout 的匿名函数执行时,它就拥有了对 e 的引用,而这个值是不会被循环改变的。for循环
有另外一个方法完成一样的工做;那就是从匿名包装器中返回一个函数。这和上面的代码效果同样。function
for(var i = 0; i < 10; i++) { setTimeout((function(e) { return function() { console.log(e); } })(i), 1000) }
转载自:http://www.9958.pw/post/js_bibao匿名函数