美文网首页
JS函数的执行时机

JS函数的执行时机

作者: 茜Akane | 来源:发表于2021-01-27 00:54 被阅读0次

    JS函数的执行时机

    在解释JS函数的执行时机之前,先来看一个例子

    let i = 0
    for(i = 0; i<6; i++){
      setTimeout(()=>{
        console.log(i)
      },0)
    }
    

    将console.log打印出来是什么呢?
    答案是6个6!!

    • 那么为什么呢?
      从代码上一行一行来看,当for循环每执行一次时,setTimeout都会执行一次,但因为setTimeout是异步方法,里面的函数被放到了任务队列里面等一会儿。当主线程执行完毕,也就是for循环执行完成之后,存放在任务队列中的函数开始执行,执行的次数是根据for循环的次数得出的。与此同时,i 的值已增加成了6,6不符合i<6的条件,所以for循环停止,所以会输出6个6。
    如果我想打印 0、1、2、3、4、5 要怎么办呢
    for(let i = 0; i<6; i++){
      setTimeout(()=>{
        console.log(i)
      },0)
    }
    

    在for循环i的初始化加上let。
    因为let元素遵循块作用域,所以在for循环语句的括号里使用并赋值let时,会产生一个隐藏的作用域。在每次执行for循环时,JS会保留i的初始值,然后重新声明执行一次。

    除了使用 for let还能怎么做呢
    for(var i = 0;i<6;i++){
        !function(i){
           setTimeout(()=>{
             console.log(i)
            },0)      
        }(i)
    }
    

    使用立即执行函数,可以创建一个局部变量,然后也可以实现使用let的结果。

    相关文章

      网友评论

          本文标题:JS函数的执行时机

          本文链接:https://www.haomeiwen.com/subject/nfhozktx.html