1,4,3,2html
Promise是一个micro task 主线程是一个task micro task queue会在task后面执行vue
setTimeout返回的函数是一个新的task macro task queuehtml5
因此Promise会先于新task执行api
根据html标准 一个task执行完后 ui会重渲染 promise
vue源码: nextTick异步更新dom操做先判断是否支持Promise 再判断是否支持MutationObserve 最后是setTimeoutdom
macroTask Queue(宏任务队列) : setTimeout setInterval setImmediate requestAnimationFrame NodeJS的I/O异步
microTask Queue(微任务队列):函数
promise (独立回调)其成功/失败回调函数相互独立ui
复合回调: Object.observe, MutationObserver 和NodeJs中的 process.nextTick ,不一样状态回调在同一函数体线程
requestAnimationFrame是html5的api 有兼容性问题 可是精度比较高
它的时间间隔是系统决定的 保证屏幕刷新一次 回调函数只执行一次 好比屏幕刷新的频率是60hz 间隔1000ms/60hz执行一次回调