news 2026/4/19 5:57:19

Vue3 渲染调度机制(异步更新)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Vue3 渲染调度机制(异步更新)

目录

  • 前言
  • 一、「渲染调度机制」总览
  • 二、为什么需要“调度”?
  • 三、Vue 的队列
    • 1、Vue 组件更新会立即执行吗?
    • 2、Vue 的三种核心队列
      • (1)、调度总入口:queueJob()
      • (2)、queueFlush():开启“异步更新”
      • (3)、真正执行更新:flushJobs()
        • ①、先执行 pre 队列
        • ②、再执行组件更新(render + patch)
        • ③、最后执行 post 队列
    • 3、为什么还要排序?
  • 四、调度机制解决了哪些问题?
  • 五、nextTick 本质是什么?(⭐️⭐️⭐️⭐️⭐️)
  • 六、整个调度流程串起来

前言

Vue3 在响应式数据触发更新时,不会立即执行组件渲染,而是通过调度器将更新任务放入队列,并利用微任务在当前事件循环结束后统一批量执行。调度器内部会对任务去重,并按照组件创建顺序排序,确保父子组件更新顺序正确。同时 Vue 还维护 pre 和 post 两类副作用队列,用于控制 watch 等副作用的执行时机,从而实现高性能、可预测的 UI 更新机制。

一、「渲染调度机制」总览

Vue3 渲染调度机制 =把多次状态变化合并起来,按顺序、分批次、异步地执行组件更新

关键词就三个:

  • 队列
  • 去重
  • 异步批处理

二、为什么需要“调度”?

看一段代码:

state.count++state.count++state.count++

如果每次修改都立刻:

trigger → effect → render → patch

那页面会 连续重渲染 3 次,纯纯浪费性能。

Vue 的目标是:

  • 不管你一口气改多少次数据,一个组件一轮事件循环只更新一次

这就是调度器的使命。

三、Vue 的队列

1、Vue 组件更新会立即执行吗?

不会。

Vue 组件更新不会立刻执行,而是先进“更新队列”。

当响应式数据触发 trigger() 时:

triggerEffects(dep)

内部不会直接执行组件的副作用,而是:

queueJob(effect)

也就是说:

❗组件更新 = 被放进一个“待执行任务队列”

2、Vue 的三种核心队列

队列存什么什么时候执行
queue组件更新任务主要渲染阶段
pendingPreFlushCbswatchEffect/watch(flush:‘pre’)渲染前
pendingPostFlushCbswatch(..., { flush:'post' })DOM 更新后

(1)、调度总入口:queueJob()

源码逻辑(简化):

constqueue:Job[]=[]letisFlushing=falseexportfunctionqueueJob(job){if(!queue.includes(job)){// ⭐ 去重queue.push(job)queueFlush()}}

关键点 1:去重

同一个组件不管触发多少次,只会保留一个更新任务。

(2)、queueFlush():开启“异步更新”

functionqueueFlush(){if(!isFlushing){isFlushing=truePromise.resolve().then(flushJobs)}}

关键点 2:微任务异步执行

Vue 使用的是:

Promise.then → 微任务

这就解释了为什么:

state.count++console.log(dom)// 旧 DOMawaitnextTick()console.log(dom)// 新 DOM

因为 DOM 更新在 本轮同步代码执行完后才发生。

(3)、真正执行更新:flushJobs()

functionflushJobs(){try{flushPreFlushCbs()// 1️⃣ 执行 pre 队列queue.sort(sortJob)// 2️⃣ 排序(父 → 子)for(jobofqueue){// 3️⃣ 执行组件更新job()}}finally{flushPostFlushCbs()// 4️⃣ 执行 post 队列resetSchedulerState()}}

执行顺序非常重要!

  • 先执行 pre 队列
  • 再执行组件更新(render + patch)
  • 最后执行 post 队列
①、先执行 pre 队列

用于:

watchEffect(fn)// 默认 flush: 'pre'watch(source,fn)

此时 DOM 还没更新,适合做:

  • 读取旧 DOM 状态
  • 计算下一步逻辑
②、再执行组件更新(render + patch)

就是我们熟悉的:

effect → render → patch

这一步才真正改 DOM。

③、最后执行 post 队列

用于:

watch(source,fn,{flush:'post'})

此时 DOM 已经是最新的。

适合:

  • 访问更新后的 DOM
  • 操作第三方库

3、为什么还要排序?

queue.sort((a,b)=>getId(a)-getId(b))

组件创建时有递增 id:

父组件 id<子组件 id

排序的意义是:

  • ✅ 保证父组件先更新,子组件后更新

否则可能出现:

  • 子组件基于旧 props 更新
  • 父组件晚更新导致数据错乱

四、调度机制解决了哪些问题?

问题Vue 怎么解决
多次数据变更频繁重渲染队列去重 + 批量执行
更新顺序错乱按组件创建顺序排序
DOM 访问时机混乱pre / post 队列分离
同步更新阻塞 UI微任务异步更新

五、nextTick 本质是什么?(⭐️⭐️⭐️⭐️⭐️)

exportfunctionnextTick(fn?){returnfn?Promise.resolve().then(fn):Promise.resolve()}

它只是:

  • 等待当前这轮“组件更新批处理”结束。

所以:

state.count++awaitnextTick()// 这里 DOM 一定是新的

六、整个调度流程串起来

响应式数据改变 │ ▼trigger()│ ▼queueJob(组件effect)│ ▼Promise.then(微任务)│ ▼flushJobs()│ │ ▼ ▼ pre队列 组件render+patch │ ▼ post队列
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/30 19:30:09

【毕业设计】基于springboot+小程序的24小时自助棋牌室小程序的设计与实现(源码+文档+远程调试,全bao定制等)

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/4/11 16:33:42

‌能耗优化工具:LSTM预测模型驱动的移动端电池衰减测试框架‌

2026年&#xff0c;软件测试公众号内容热度主要由AI工具评测、实战教程和精准测试案例驱动&#xff0c;阅读量平均提升35%&#xff0c;其中AI相关主题占比超60%&#xff0c;成为最热门赛道。用户群体&#xff08;软件测试从业者&#xff09;更关注能解决高频痛点的内容&#xf…

作者头像 李华
网站建设 2026/4/17 23:26:29

计算机Java毕设实战-基于springboot+vue的医院技能教学培训管理系统【完整源码+LW+部署说明+演示视频,全bao一条龙等】

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/4/19 2:46:42

金融风控平台如何通过wangEditor实现Word多级列表转存?

金融业务系统后台编辑器升级方案&#xff1a;Word 文档导入与粘贴功能增强 一、项目背景 在金融行业快速数字化转型的当下&#xff0c;业务系统的高效性与灵活性成为提升竞争力的关键因素。公司现有的金融业务系统后台编辑器&#xff0c;在处理复杂文本内容时存在一定局限性&…

作者头像 李华
网站建设 2026/4/17 22:32:06

逆天!Mata用13个参数26字节让模型正确率从76%飙升至91%

逆天&#xff01;用13个参数&#xff0c;26字节&#xff0c;还没有一条短信长&#xff0c;就教大模型提升数学推理能力。一个80亿参数的庞大语言模型&#xff0c;就像一座储存了海量知识的宏伟图书馆。现在&#xff0c;你需要教会它一项新技能——解数学应用题。传统方法需要对…

作者头像 李华