广告
返回顶部
首页 > 资讯 > 精选 >JS异步的执行顺序是什么
  • 500
分享到

JS异步的执行顺序是什么

2023-07-02 11:07:58 500人浏览 薄情痞子
摘要

这篇文章主要介绍“js异步的执行顺序是什么”,在日常操作中,相信很多人在JS异步的执行顺序是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”JS异步的执行顺序是什么”的疑惑有所帮助!接下来,请跟着小编一起来

这篇文章主要介绍“js异步的执行顺序是什么”,在日常操作中,相信很多人在JS异步的执行顺序是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”JS异步的执行顺序是什么”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

  • js的执行顺序,先同步后异步

  • 异步中任务队列的执行顺序: 先微任务microtask队列,再宏任务Macrotask队列

  • 调用Promise 中的resolve,reject属于微任务队列,setTimeout属于宏任务队列

注意以上都是 队列,先进先出。

微任务包括 `process.nextTick` ,`promise` ,`MutationObserver`。

宏任务包括 `script` , `setTimeout` ,`setInterval` ,`setImmediate` ,`I/O` ,`UI rendering`。

node环境下,process.nextTick的优先级高于Promise,也就是可以简单理解为:在宏任务结束后会先执行微任务队列中的nextTickQueue部分,然后才会执行微任务中的Promise部分。

javascript事件机制

JS异步的执行顺序是什么

题目1:

console.log('script start') async function async1() {  await async2()  console.log('async1 end')}async function async2() {  console.log('async2 end')}async1() setTimeout(function() {  console.log('setTimeout')}, 0) new Promise(resolve => {  console.log('Promise')  resolve()}).then(function() {  console.log('promise1')}).then(function() {  console.log('promise2')}) console.log('script end')

执行结果?

分析:

首先执行 同步代码:

  • 首先执行    console.log('script start')

  • 执行 async1() 的时候,马上执行了 async2函数:console.log('async2 end')

  • 顺序执行 new Promise()中的同步函数:console.log('Promise')

  • 最后执行  console.log('script end')。

上面是同步执行的代码,然后看剩下的异步执行的代码:

首先,setTimeout是 宏观任务,排除到最后,剩下微观任务:

async function async1() {  await async2()  console.log('async1 end')}new Promise(resolve => {  resolve()}).then(function() {  console.log('promise1')}).then(function() {  console.log('promise2')})
  • 然后根据先入先出的对列方式,先执行await async2() 后面阻碍的函数console.log('async1 end')

  • 执行promise的resolve函数

new Promise(resolve => {  resolve()})

也就是接下来的两个then:console.log('promise1') ----console.log('promise2') ;

  • 最后执行的是 setTimeout函数console.log('setTimeout') ;

综上所述,以上代码执行的顺序是:

script start >> 2.async2 end >> 3.Promise >> 4.script end >> 5.async1 end >> 6.promise1 >> 7.promise2 >> 8.setTimeout

题目2:

(function() {     setTimeout(() => {        console.log(0);    });     new Promise(resolve => {        console.log(1);         setTimeout(() => {            resolve();            Promise.resolve().then(() => console.log(2));            console.log(3);        });         Promise.resolve().then(() => console.log(4));     }).then(() => {        console.log(5);        Promise.resolve().then(() => console.log(8));        setTimeout(() => console.log(6));    });     console.log(7); })();
  • 同样先执行同步代码,且先把setTimeout去掉:

new Promise(resolve => {      console.log(1);      Promise.resolve().then(() => console.log(4)); //微观任务  }).then(() => {                  //then函数是执行对应的 resolve 的时候才执行的      console.log(5);      Promise.resolve().then(() => console.log(8));//微观任务 }); console.log(7);

可以看出先执行:console.log(1);console.log(7);

  • 执行微任务Promise.resolve().then(() => console.log(4));

代码变成了:

(function() {  setTimeout(() => {      console.log(0);  });  new Promise(resolve => {      setTimeout(() => {          resolve();          Promise.resolve().then(() => console.log(2));          console.log(3);      });  }).then(() => {      console.log(5);      Promise.resolve().then(() => console.log(8)); //这句是多加的      setTimeout(() => console.log(6));  });})();

只剩下宏观任务(微观任务在宏观任务里,也就是宏观任务外面不在有微观任务了)

  • 执行console.log(0);

  • 再执行 new Promise 中的 setTimeout,先执行里面的同步函数:console.log(3)

  • 再执行上面的 resolve,对应的是下面的then函数:

then(() => {      console.log(5);      Promise.resolve().then(() => console.log(8)); //这句是多加的      setTimeout(() => console.log(6)); }

所以先执行console.log(5);

剩下的都是微观任务和宏观任务,先看微观任务:

new Promise(resolve => {     resolve();     Promise.resolve().then(() => console.log(2)); }).then(() => {     Promise.resolve().then(() => console.log(8));     setTimeout(() => console.log(6)); });

所以根据队列中的微观任务顺序先执行:console.log(2),在执行then中的console.log(8);

最后再执行 console.log(6)

综上所述,结果为

1/7/4/0/3/5/2/8/6

题目3:

(function() {    setTimeout(() => {        console.log(0);    });     new Promise(resolve => {         console.log(1);                 setTimeout(() => {            resolve();            Promise.resolve().then(() => {                console.log(2);                setTimeout(() => console.log(3));                Promise.resolve().then(() => console.log(4));            });        });         Promise.resolve().then(() => console.log(5));     }).then(() => {         console.log(6);        Promise.resolve().then(() => console.log(7));        setTimeout(() => console.log(8));     });     console.log(9);})();

解释如下:【同步>异步;微任务>宏任务】第一步:打印出1、9;如图

JS异步的执行顺序是什么

图a

由图a中的任务队列可知:
第二步: 执行微任务3,打印出5;
第三步:执行宏任务1,打印出0,
第四步:开始执行宏任务2;如图:

JS异步的执行顺序是什么

图b

由图b中的任务队列可知, 执行微任务4,打印出6,如图:

JS异步的执行顺序是什么

图c

由图c中的任务队列可知, 执行微任务5,打印出2;如图

JS异步的执行顺序是什么

图d

由图d的任务队列可知,
第七步:执行微任务6,打印出7;
第八步:执行微任务9,打印出4;
第九步:执行宏任务7,打印出8;
第十步:执行宏任务8,打印出3;

即答案是:

1-9-5-0-6-2-7-4-8-3

到此,关于“JS异步的执行顺序是什么”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

--结束END--

本文标题: JS异步的执行顺序是什么

本文链接: https://www.lsjlt.com/news/341604.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • JS异步的执行顺序是什么
    这篇文章主要介绍“JS异步的执行顺序是什么”,在日常操作中,相信很多人在JS异步的执行顺序是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”JS异步的执行顺序是什么”的疑惑有所帮助!接下来,请跟着小编一起来...
    99+
    2023-07-02
  • JS异步的执行顺序分析
    1.js的执行顺序,先同步后异步2.异步中任务队列的执行顺序: 先微任务microtask队列,再宏任务macrotask队列3.调用Promise 中的resolve,reject...
    99+
    2022-11-13
  • mysql的执行顺序是什么
    mysql的执行顺序是什么?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。1、执行顺序根据查询指定的表格,from计算笛卡尔积。on根据join_condition过滤数据。...
    99+
    2023-06-14
  • JS下大批量异步任务按顺序执行的示例分析
    这篇文章主要介绍了JS下大批量异步任务按顺序执行的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。前言最近需要做一个浏览器的, 支持大...
    99+
    2022-10-19
  • golang defer的执行顺序是什么
    在Go语言中,defer语句用于注册延迟调用,延迟调用会在函数执行完毕后被执行,无论函数是正常返回还是发生异常。 当有多个defer...
    99+
    2023-10-22
    golang
  • SQL查询的执行顺序是什么
    本篇内容主要讲解“SQL查询的执行顺序是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“SQL查询的执行顺序是什么”吧!很多 SQL 查询都是以 SELEC&...
    99+
    2022-10-19
  • switch语句执行顺序是什么
    switch语句执行顺序是按照case标签的顺序进行判断,从上到下逐个比较。当找到与表达式匹配的case标签时,会执行该case标签...
    99+
    2023-09-16
    switch
  • sql和mysql执行顺序是什么
    这篇文章主要介绍了sql和mysql执行顺序是什么,具有一定借鉴价值,需要的朋友可以参考下。希望大家阅读完这篇文章后大有收获。下面让小编带着大家一起了解一下。sql和mysql执行顺序,内部机制是一样的,最...
    99+
    2022-10-18
  • java代码块的执行顺序是什么
    Java代码块的执行顺序如下: 静态代码块:静态代码块在类加载时执行,并且只执行一次。它用来初始化静态变量或执行一些只需执行一次...
    99+
    2023-10-24
    java
  • where子句的执行顺序是什么
    本篇内容介绍了“where子句的执行顺序是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! ...
    99+
    2022-10-18
  • java构造器的执行顺序是什么
    这篇文章给大家介绍java构造器的执行顺序是什么,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。1,在没有静态块的情况下,子类的对象创建时,父类的无参构造器-->子类的构造器(产生对象的构造器,如果是无参则执行的是...
    99+
    2023-06-17
  • java过滤器执行顺序是什么
    Java过滤器的执行顺序是根据过滤器的配置顺序来确定的。在web.xml文件中,过滤器的配置顺序决定了它们的执行顺序。当一个请求被发...
    99+
    2023-08-11
    java
  • ​mysql中语句执行顺序是什么
    这篇文章给大家分享的是有关mysql中语句执行顺序是什么的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。MySQL的语句一共分为11步,如下图所标注的那样,最先执行的总是FROM操...
    99+
    2022-10-18
  • Java监听器MouseListener的执行顺序是什么
    Java监听器MouseListener的执行顺序是按照以下顺序执行的:1. 鼠标按下事件:mousePressed()2. 鼠标释...
    99+
    2023-08-16
    Java
  • PHP中for循环的执行顺序是什么
    本教程操作环境:windows7系统、PHP7.1版,DELL G3电脑for 循环是 PHP 中最复杂的循环结构。for 循环语句能够按照已知的循环次数进行循环操作,适用于明确知道执行次数的情况。for 循环的语法格式如下:for (初始...
    99+
    2016-02-26
    PHP for循环
  • C#类中方法的执行顺序是什么
    有些中级开发小伙伴还是搞不太明白在继承父类以及不同场景实例化的情况下,父类和子类的各种方法的执行顺序到底是什么,下面通过场景的举例来重新认识下方法的执行顺序: (下面内容涉及到了C#...
    99+
    2022-11-12
  • java中代码块的执行顺序是什么
    java中代码块的执行顺序是什么?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。常用的java框架有哪些1.SpringMVC,Spring Web MVC是一种基于Java...
    99+
    2023-06-14
  • Angular生命周期执行的顺序是什么
    这篇文章主要介绍“Angular生命周期执行的顺序是什么”,在日常操作中,相信很多人在Angular生命周期执行的顺序是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Angular生命周期执行的顺序是什么...
    99+
    2023-07-05
  • Java监听器ActionListener的执行顺序是什么
    Java监听器ActionListener的执行顺序是按照事件的触发顺序来决定的。当事件发生时,监听器会按照注册顺序依次执行。例如,...
    99+
    2023-08-16
    Java
  • JavaScript如何实现异步任务循环顺序执行
    今天小编给大家分享一下JavaScript如何实现异步任务循环顺序执行的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。需求场景...
    99+
    2023-07-05
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作