6个6

1、理解6个6
let i 
for(i=0; i<6; i++){ 
    setTimeout(()=>{console.log(i)},1000) 
}
 
结果是:6个6,不是0、1、2、3、4、5
 
原因:
首先理解setTimeout()这个函数方法,上面例子按照平常理解是1秒后输出 i 
但真正意义上是,1秒后尽快执行这个方法。不是1s后立即执行。
 
理解后,就懂了为什么会输出是6个6,因为当轮到方法输出时,i=6 , 
 
那么怎样正常输出?
第一种方法:
for(let i=0; i<6; i++){ 
    setTimeout(()=>{console.log(i)},1000) 
}
这是JS提供的一个语法糖,当运行时,每一个值都会开辟一个空间,存储i的值
 
 
第二种方法:立即执行函数
for(var i=0; i<6; i++){
    !function(i){
        setTimeout(()=>{console.log(i)},1000)
    }(i)
}

 

posted @ 2021-03-08 19:42  蛰鸣  阅读(291)  评论(0编辑  收藏  举报