for(var i=0; i<5; i++) {
setTimeout(function() {
console.info(i);
}, 0);
}
console.info(i); // 这里为什么输出的是5
for(var i=0; i<5; i++) {
setTimeout(function() {
console.info(i);
}, 0);
}
console.info(i); // 这里为什么输出的是5
var 声明符是函数作用域,虽然声明 i 的时候是在 for 循环里面,但是 var 有一个申明提升,提升到所在函数顶端,所以在 for 下面也可以访问到 i。
es6 有新的 const 和 let 声明符就是块作用域了。
js(es5)中,var声明的变量没有块级作用域。
在es6中可以用let声明解决此问题。
for(var i=0; i<5; i++) {
setTimeout(function() {
console.info(i);
}, 0);
}
console.info(i);
to
(function (){
for(var i=0; i<5; i++) {
setTimeout(function() {
console.info(i);
}, 0);
}
})();
console.info(i); // undefined
前两天写的文章刚好是分析这个的:
https://segmentfault.com/a/11...
贴过来你自己跑下试试,自己照着例子分析一遍最有收获。
希望能帮助到你。
8 回答4.5k 阅读✓ 已解决
6 回答3k 阅读✓ 已解决
5 回答2.6k 阅读✓ 已解决
5 回答6.2k 阅读✓ 已解决
4 回答2.2k 阅读✓ 已解决
3 回答2.4k 阅读
4 回答2.7k 阅读✓ 已解决
http://www.qdfuns.com/notes/1... 这有详细的解释