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

《JS 函数的执行时机》

作者: Yandhi233 | 来源:发表于2021-09-12 16:18 被阅读0次

1. 为什么以下代码会打印出 6 个 6

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

要搞清楚这个问题,首先要要了解 JS 函数的执行机制和作用域

  • JS 的执行机制: JS 是单线程环境,是从上到下依次执行的,即 同步执行;for 循环是同步代码,setTimeout异步代码。JS 在执行代码的过程中,碰到同步代码会依次执行,碰到异步代码就会将其放入任务队列中进行等待,当同步代码执行完毕后再开始执行异步代码,即 异步执行
  • JS函数作用域:当同步代码执行完毕后,开始执行异步的setTimeout代码,执行setTimeout时需要从当前作用域内寻找一个变量i,此时 for 循环已执行完毕,当前 i=6,所以执行setTimeout时输出为 6,任务队列中的剩余5个setTimeout也依次执行,输出为6。

2. for 循环和 let 配合使用使上面代码打印 0、1、2、3、4、5

示例如下:

    for(let i = 0; i<6; i++){
        setTimeout(()=>{
           console.log(i)
        },0)
    } 
    //  0,1,2,3,4,5

因为let变量的作用域只能在当前函数中,所以每次 for 循环生成的都是一个新的 i,
setTimeout里输出的i就是这个新的 i,这个 i 是不会变化的,所以输出的就是正常的。

3. 其他方法

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

每次循环都会调用 fn,每次传入的i都只保存在当轮循环的 fn 中。由于每次传入的i的值都不一样,所以每次打出的结果也不会相同。

相关文章

  • 2020-11-07

    JS 函数的执行时机 函数的执行时机不同结果也会不同,js也分为同步执行和异步执行 简单的举几个同步执行例子1、 ...

  • JS函数的执行时机

    JS函数的执行时机 在解释JS函数的执行时机之前,先来看一个例子 将console.log打印出来是什么呢?答案是...

  • JS函数执行时机

    请问下面这段代码会打印什么结果 打印出6 个6解析:因为i作用域,不属于 for 循环体,属于 global;等到...

  • JS 函数的执行时机

    1. 常见的面试题代码解释 // 6 个 6JS是单线程运行的,setTimeout(code,millisec)...

  • JS 函数的执行时机

    为什么打印出6 个 6? setTimeout 会过一段时间才去执行,这时候for已经循环完了所以打出6个6 为什...

  • JS 函数的执行时机

    1 解释为什么如下代码会打印 6 个 6 变量i在for循环中执行i++. 最后一次i++ ,i=6,for循环不...

  • JS 函数的执行时机

    1 解释为什么如下代码会打印 6 个 6 -函数一共会执行6次循环,每次循环到i = 6的时候就打印出值-在有se...

  • JS函数的执行时机

    JS函数中,对函数调用的时机不同,得到的结果也会不一样,例如 下面这段代码 : 执行结果如下 : 结果显示打印出来...

  • JS 函数的执行时机

    结果:6个6原因:setTimeout表示尽快执行,即要做完当前的事情再执行,而此代码里当前事情只有for里面的事...

  • JS 函数的执行时机

    一、为什么如下代码会打印出六个6 setTimeout是指过一会儿再执行,也就是循环执行完再打印,当循环6次后,i...

网友评论

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

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