美文网首页饥人谷技术博客
JS 函数的执行时机

JS 函数的执行时机

作者: 招投标秘籍 | 来源:发表于2021-04-03 21:33 被阅读0次

1.同步和异步的区别

我们都知道JS里面有同步和异步的区别,怎么理解同步和异步呢。一家餐厅吧来了5个客人,同步的意思就是说,来第一个点菜,点了个鸡,厨师去捉鸡杀鸡,过了半小时鸡好了给第一位客人,开始下位一位客人,就这样一个一个来,按顺序来相同。异步的意思就是来第一位客人,点什么,点鱼,给它一个牌子,让他去一边等吧,下一位客人接着点菜,点完接着点让厨师做去吧,哪个的菜先好就先端出来。今天主要结束

2.setTimeout函数

2.1函数执行的顺序

我们今天通过setTimeout函数来理解一下异步,通过这个例子大家可以更好的理解。

let i = 0
for(i = 0; i<6; i++){
  setTimeout(()=>{
    console.log(i)
  },0)
}//打印出6个6
图片.png

大家肯定很意外为什么是打印出6个6,而不是0,1,2,3,4,5,接下来就跟大家来解释一下这个函数的执行顺序,setTimeout函数表示过一会在执行,所以上面这个函数的执行顺序为:
1.i赋值为0
2.判断i < 6 ?,满足进入第一循环
3.setTimeout()会过一会执行–>跳过setTimeout()继续执行
4.执行i++,此时i的值为1
5.判断i < 6 ?,满足进入第二循环
6.setTimeout()会过一会执行–>跳过setTimeout()继续执行
7.执行i++,此时i的值为2
省略…
执行i++,此时i的值为6
判断i < 6 ?,不满足跳出循环
执行第一次循环的setTimeout() //打印出a
执行第二次循环的setTimeout() //打印出a
执行第三次循环的setTimeout() //打印出a
执行第四次循环的setTimeout() //打印出a
执行第五次循环的setTimeout() //打印出a
执行第六次循环的setTimeout() //打印出a
结束

2.2setTimeout过一会儿执行怎么理解

意思就是不用再等多少秒了,就是当同步任务的函数和语句执行完后,0秒或者立刻执行setTimeout函数了。

2.3那如果想要打印出0、1、2、3、4、5呢?

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

所以这样就可以啦

2.4其他方法解决(利用 const 关键字)

let i
for(i = 0; i<6; i++){
    const x = i
    setTimeout(()=>{
      console.log(x)
    })
}
图片.png

这样就可以啦~
本文为本人的原创文章,著作权归本人和饥人谷所有,转载务必注明来源.

相关文章

  • 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/bndhkltx.html