第一种情况
for (var i = 0; i < 10; i++) {
setTimeout(function(){
console.log('i-'+i);
return function(){
console.log('i-'+i);
}
}(), 2000)
}
执行结果为 i-1,i-2...i-9 。两秒后输出 10 次 i-10
第二种情况 将代码改为如下
for (var i = 0; i < 10; i++) {
setTimeout(function(){
var s = i
console.log('i-'+i);
return function(){
console.log('s-'+s);
}
}(), 2000)
}
执行结果为 i-1,i-2...i-9 。两秒后输出 s-1,s-2...s-9
第三种情况
for (var i = 0; i < 10; i++) {
(function(){
console.log('i-'+i);
return function(){
console.log('s-'+i);
}()
})()
}
执行结果为i-1,s-1...i-9,s-9 这是什么原因呢
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.