热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

promise异步是在当前eventloop任务队列尾部添加其回调函数么?

1234567891011121314151617  (function () {    console.log(1);    var p4 = new Promise((resolve, rejec

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
  (function () {

    console.log(1);

    var p4 = new Promise((resolve, reject) => {

      resolve('ok');

      setTimeout(() => {

        console.log(6)

      }, 500);

      console.log(2);

    });

    console.log(3);

    p4.then(value => {

      console.log(5);

      console.log(value);

    });

    console.log(4);

  })();

  // 1 2 3 4 5 ok undefined 6

问题:打印顺序为 4 5 ok 6?
这样理解正确么?Promise 异步是当前 event loop 的任务队列队尾添加了 resolve 的回调函数,而 setTimeout 我们知道是会下下一轮 event loop 的任务队列尾部添加回调函数。





   



推荐阅读
author-avatar
愿今夜不再孤单
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有