JUEJIN小册|前端性能优化|渲染篇 4:千方百计——Event Loop 与异步更新策略

本文探讨了Event Loop机制在前端性能优化中的作用,特别是Vue和React的异步更新策略。通过分析宏任务和微任务,指出在DOM更新时选择微任务能提高渲染效率。以Vue的nextTick为例,展示了异步更新如何减少DOM操作,避免无效渲染,从而实现DOM优化。
摘要由CSDN通过智能技术生成

千方百计——Event Loop 与异步更新策略

Vue 和 React 都实现了异步更新策略。虽然实现的方式不尽相同,但都达到了减少 DOM 操作、避免过度渲染的目的。通过研究框架的运行机制,其设计思路将深化我们对 DOM 优化的理解,其实现手法将拓宽我们对 DOM 实践的认知。

本节我们将基于 Event Loop 机制,对 Vue 的异步更新策略作探讨。

前置知识:Event Loop 中的“渲染时机”

搞懂 Event Loop,是理解 Vue 对 DOM 操作优化的第一步。

Micro-Task 与 Macro-Task

事件循环中的异步队列有两种:macro(宏任务)队列和 micro(微任务)队列。

常见的 macro-task 比如: setTimeout、setInterval、 setImmediate、script(整体代码)、 I/O 操作、UI 渲染等。
常见的 micro-task 比如: process.nextTick、Promise、MutationObserver 等。
micro-task:procss.nextTic,promise,mutationObsrvr

Event Loop 过程解析

基于对 micro 和 macro 的认知,我们来走一遍完整的事件循环过程。

一个完整的 Event Loop 过程,可以概括为以下阶段:
● 初始状态:调用栈空。micro 队列空,macro 队列里有且只有一个 script 脚本&#

  • 4
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

学习记录wanxiaowan

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值