其他分享
首页 > 其他分享> > 关于JS函数的执行时机

关于JS函数的执行时机

作者:互联网

1-为什么如下代码会打印 6 个 6。  
let i = 0
for(i = 0; i<6; i++){
  setTimeout(()=>{
    console.log(i)
  },0)
}

当for循环每执行一次时,setTimeout都会执行一次,但因为setTimeout是异步方法,所以里面的函数并没有执行,而是被放到了任务队列里面。当主线程执行完毕,也就是for循环执行完成后。存放在任务队列中的函数会被执行,执行的次数是根据for循环的次数得出的。与此同时,i 的值已增加成了6,所以会输出6个6。

2-打印 0、1、2、3、4、5 的方法。  
for(let i = 0; i<6; i++){
  setTimeout(()=>{
    console.log(i)
  },0)
}
因为let元素遵循块作用域,所以在for循环语句的括号里使用并赋值let时,会产生一个隐藏的作用域。在每次执行for循环时,JS会保留i的初始值,然后重新声明执行一次。   3-除了使用 for let 配合,还有什么其他方法可以打印出 0、1、2、3、4、5)。  
for(var i = 0;i<6;i++){
    !function(i){
       setTimeout(()=>{
         console.log(i)
        },0)       
    }(i)
}
 使用立即执行函数,可以创建一个局部变量,然后也可以实现使用let的结果。

 

标签:console,函数,JS,循环,let,时机,执行,log
来源: https://www.cnblogs.com/yxks-666/p/14328039.html