经典的案例
let arr = []
for(var i =0;i<=5;i++){
arr[i]= function fn(){
console.log(i)
}
}
arr[0]() //6
解析:我们的想法是arr[0]的函数应该是打印0的,而且每个元素的函数都能打印出自己的索引才对,可结果出乎意料。实际上为啥是6,我们先逐步分析。
1.js没有块级作用域
for(var i =0;i<=5;i++){
b=3
console.log(i)
}
{var a =1}
console.log('结果:',a,b) //结果: 1 3
也就是说,在大括号中声明的变量在大括号外部能拿到。这些变量是全局变量。
2.函数操作的变量值是函数调用时的而非函数声明时的
var a = 1
var fn = function(){
console.log('a:',a)
}
a=2
fn() //a:2
函数声明时变量a的值是1,声明后a的值变成了2,此时再调用fn函数,取得的a是2.
3.for循环的变量泄漏
let arr =