Node中的宏任务、微任务有什么
宏任务: script(整体代码), setTimeout, setInterval, setImmediate, I/O, UI rendering
微任务: process.nextTick, Promises(这里指浏览器实现的原生 Promise),Object.observe, MutationObserver
setImmediate是什么
setImmediate类似setTimeout。接受一个回调函数,及可选回调的参数。属于宏任务,回调函数会被放置到下一个事件循环的check阶段。
和setTimeout相比,更适合长时间大型程序的运行。
而process.nextTick的回调会在当前事件循环结束后进行,比setImmediate早。
Vue.nextTick
Vue中当有DOM操作时并不会即刻更新,会统一记录在下一个事件循环队列进行更新。nextTick中的传入的回调或者then中接收的回调会在DOM更新后立刻执行。
async/await语法糖
async关键字声明一个函数,函数返回的结果会被包装成一个Promise对象。
await 关键字后面等待一个Promise的结果,若不是Promise则会直接返回值。await后面的代码会在await等待后执行。
作为一个generator语法糖:将异步代码以同步方式编写。
可迭代的数据类型
可迭代数据对象:
字符串、数组、Map、Set、arguments、NodeList等DOMClotion类型。
数字,对象类型不可迭代

本文详细介绍了JavaScript中的宏任务与微任务,包括setImmediate、Promise、process.nextTick以及Vue.nextTick的工作原理。阐述了它们在事件循环中的执行顺序,并分析了async/await作为异步语法糖的作用。此外,还探讨了HTTP协议从1.1到2.0的性能优化,如多路复用、二进制编码和首部压缩。最后,简述了CORS跨域的简单请求与非简单请求的区别。
最低0.47元/天 解锁文章
7906

被折叠的 条评论
为什么被折叠?



