当前位置: 首页 > news >正文

Vue响应式原理

Vue响应式原理

  • 数据劫持:vue2的Object.defineProperty(对属性添加getter和setter方法),vue3的Proxy。
  • 依赖收集:模板渲染时收集,computed收集,watch收集。
  • 依赖执行:将收集到的依赖依次执行。
    依赖其实就是数据变化时要执行的函数。

依赖收集

Vue 响应式依赖收集的核心是收集数据变化时需要重新执行的代码,具体包括:

  • 组件模板渲染的「更新函数」(最核心);
  • 计算属性的「求值函数」;
  • watch/watcher 的用户自定义的「回调函数」;
  • 手动通过 watchEffect/ReactiveEffect 等 API 定义的「自定义函数」。

依赖收集的本质是「响应式数据与执行函数的映射」,数据变化时通过映射关系精准触发函数执行,这也是 Vue 实现「数据驱动视图」的核心原理。

源码解析

vue2是通过Dep类收集(watcher),Dep类维护一个watcher数组,数据变化时通知watcher更新。
vue3是通过effect函数收集。get时调用track收集依赖,set时调用trigger触发所有的effect更新。

vue2通过watcher类收集依赖

  • 渲染watcher
    每个组件在挂载时都会创建一个渲染watcher,负责渲染视图时的依赖收集。
newWatcher(vm,updateComponent,noop,watcherOptions,true)/* isRenderWatcher */
  • 计算属性(缓存)
    每一个计算属性内部维护一个dirty属性,表示是否需要重新计算。
    当取值时dirty为true就会执行计算函数计算值,拿到值缓存起来this.value, 并将dirty设置为false。
    再次取值时,dirty为false就直接返回缓存的值this.value。
    当计算属性依赖的数据变化时,会将dirty设置为true,下次访问计算属性时会重新计算值。

  • 计算属性watcher(lazy:true)

newWatcher(vm,getter,noop,{lazy:true})

计算属性会创建一个计算属性watcher,lazy:true表示懒执行。不会立即执行计算函数。
通过Object.defineProperty给计算属性添加getter和setter方法。
当访问计算属性时会调用getter方法,拿到计算属性watcher,看看dirty属性是否为true,如果是true就执行计算函数计算值,并将dirty设置为false。
同时让计算属性watcher中依赖的属性收集最外层的渲染watcher,这样当计算属性依赖的数据变化时会通知渲染watcher更新视图。

  • 用户watch定义时的watcher
newWatcher(vm,expOrFn,cb,options)//cb是用户定义的回调函数。

用户通过watch选项或者$watch方法创建的watcher。

vue3通过effect函数收集依赖

  • 渲染effect:
consteffect=(instance.effect=newReactiveEffect(componentUpdateFn))
  • 计算属性effect
consteffect=newReactiveEffect(getter,()=>{if(!dirty){dirty=true// 计算属性依赖的属性变化时,通知计算属性收集的渲染effect更新triggerRefValue(computedRefImpl)}})

和vue2不一样的是,这个计算属性会收集当前组件渲染的effect作为它的依赖。不需要普通属性自己去收集渲染watcher。
计算属性依赖的属性变化时,会通知计算属性effect更新dirty, 并且计算属性会触发自己收集的渲染effect执行。

  • 用户watch effect
consteffect=newReactiveEffect(getter,()=>{// 当数据变化时执行回调job()})
http://www.cnnetsun.cn/news/105656.html

相关文章:

  • GSE宏编译器:魔兽世界玩家的技能循环自动化神器
  • DeeplxFile:突破文件翻译限制的终极解决方案
  • 针对机械设备行业一体化项目制管理解决方案
  • 别再问资质认证怎么查了!看这家公司如何用“大模型搜索”帮客户7天拿下高新认证
  • 【量子编程数据同步新突破】:如何在Q#和Python间无缝传递变量?
  • Java后端开发常见报错及解决方案:小白与大牛的问答故事
  • DeepSeek-V3实战指南:如何精准调优batch_size解决推理性能瓶颈
  • Docker Offload资源释放难题:5个你必须掌握的优化技巧
  • 全面封禁Cursor!又一家大厂,出手了~
  • 为什么你的量子模型总出错?VSCode调试面板告诉你真相
  • 【稀缺技术揭秘】:资深工程师都在用的Azure量子作业状态诊断流程
  • 免费视频增强神器:字节跳动SeedVR2让老视频秒变4K超清画质
  • VSCode Azure QDK 调试失败?(90%开发者都忽略的配置细节)
  • hsweb-framework Easy-ORM终极指南:企业级数据访问实战手册
  • 8、量子计算与技术发展:从理论根源到实际应用
  • 30、RTA API 详解:功能、使用与错误处理
  • 【量子开发效率提升10倍】:VSCode + Azure QDK标准项目模板深度解读
  • ExoPlayer直播优化终极指南:从卡顿诊断到性能提升的完整解决方案
  • 企微SCRM源码分享:源雀SCRM
  • 手把手带你打通Docker Scout+GitHub Actions集成测试全流程
  • 紧急通知:Azure QDK重大版本变更来袭,你的VSCode准备好了吗?
  • 【Azure CLI量子作业资源统计全攻略】:掌握高效资源监控的5大核心命令
  • Docker中调试Vercel AI SDK的3个隐藏技巧,90%开发者都不知道
  • VSCode + Qiskit 环境配置验证全攻略(从零到运行仅需8分钟)
  • 语雀文档备份完整指南:5分钟学会离线文档制作
  • LinearDesign深度解析:5大核心优势助力mRNA序列优化革命
  • Docker Offload任务分配实战精要(附高并发场景调优案例)
  • 窗口置顶功能:打造高效多任务工作环境
  • Docker权限校验全攻略,守护AI模型最后一道防线
  • 3步掌握APKMirror:终极安卓应用下载完全指南