JS是一门单线程的语言,这是因为它运行在浏览器的渲染主线程中,而渲染主线程只有一个。而渲染主线程承担着诸多的工作,渲染页面、执行 JS 都在其中运行。如果使用同步的方式,就极有可能导致主线程产生阻塞,从而导致消息队列中的很多其他任务无法得到执行。这样一来,一方面会导致繁忙的主线程白白的消耗时间,另一方面导致页面无法及时更新,给用户造成卡死现象。所以浏览器采用异步的方式来避免。具体做法是当某些任务发生时,比如计时器、网络、事件监听,主线程将任务交给其他线程去处理,自身立即结束任务的执行,转而执行后续代码。当其他线程完成时,将事先传递的回调函数包装成任务,加入到消息队列的末尾排队,等待主线程调度执行。在这种异步模式下,浏览器永不阻塞,从而最大限度的保证了单线程的流畅运行。
相关推荐
Juchecar1 分钟前
Vue 3 单页应用Router路由跳转示例这人是玩数学的3 分钟前
在 Cursor 中规范化生成 UI 稿实践UncleKyrie4 分钟前
🎨 市面上主流 Figma to Code MCP 对比李明卫杭州6 分钟前
CSS `clamp()` 函数详解奶丝兔蜜柚11 分钟前
栈溢出优化南半球与北海道#17 分钟前
前端引入vue-super-flow流程图插件然我23 分钟前
React 16.8:不止 Hooks 那么简单,这才是真正的划时代更新 🚀小高00737 分钟前
📈前端图片压缩实战:体积直降 80%,LCP 提升 2 倍OEC小胖胖40 分钟前
【React Hooks】封装的艺术:如何编写高质量的 React 自-定义 Hooks