• 微信公众号:美女很有趣。 工作之余,放松一下,关注即送10G+美女照片!

函数里面for循环延迟打印引发的闭包问题

开发技术 开发技术 6小时前 4次浏览

期待结果:每隔一秒输出一个累加值

  • temp1:默认,为什么不行
function fn(){
  for(var i = 0; i < 5; i++){
    setTimeout(() => {
      console.log(i)
    },i*1000)
  }
}
  • temp2:函数参数保存值,为什么可以
function fn(){
  for(var i = 0; i < 5; i++){
    function inner(j){
      setTimeout(() => {
        console.log(j)
      },j*1000)
    }
    inner(i)
  }
}
  • temp3:匿名函数传参自调,为什么可以,和temp2有什么区别
functon fn(){
  for(var i = 0; i < 5; i++){
    (function(){
      setTimeout(() => {
        console.log(i)
      },i*1000)
    })(i)
  }
}
  • temp4:使用let,为什么var不可以
function fn(){
  for(let i = 0; i < 5; i++){
    setTimeout(() => {
      console.log(i)
    },i*1000)
  }
}
  • temp5:还有啥方式

程序员灯塔
转载请注明原文链接:函数里面for循环延迟打印引发的闭包问题
喜欢 (0)