现在的位置: 首页 > 综合 > 正文

wed前端技术JS异步之宏队列与微队列

2019年11月12日 综合 ⁄ 共 670字 ⁄ 字号 评论关闭

  JS中用来存储待执行回调函数的队列包含2个不同特定的列队

  宏列队:用来保存待执行的宏任务(回调),比如:定时器回调/DOM事件回调/ajax回调

  微列队:用来保存待执行的微任务(回调),比如:promise的回调/MutationObserver的回调

  JS执行时会区别这2个队列

  JS引擎首先必须先执行所有的初始化同步任务代码

  每次准备取出第一个宏任务执行前,都要将所有的微任务一个一个取出来执行

  macrotask(宏任务)

  在浏览器端,其可以理解为该任务执行完后,在下一个macrotask执行开始前,浏览器可以进行页面渲染。触发macrotask任务的操作包括:dom事件回调,ajax回调,定时器回调

  script(整体代码)

  setTimeout、setInterval、setImmediate

  I/O、UI交互事件

  postMessage、MessageChannel

  microtask(微任务)

  可以理解为在macrotask任务执行后,页面渲染前立即执行的任务。触发microtask任务的操作包括:

  Promise回调:Promise.then

  Mutation回调:MutationObserver

  process.nextTick(Node环境)

  依次输出

  Promise onResolved1() 1

  Promise onResolved2() 2

  timeout callback1()

  Promise onResolved3() 3

  timeout callback2()

抱歉!评论已关闭.