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

vue2源码阅读理解-响应式数据原理

首先明确,vue2是如何实现响应式的?
通过object.defineProperty+观察者模式实现,在创建vue实例的过程中,也就是介于beforecomputed~computed的过程中,会执行如下函数initState

export function initState (vm: Component) {vm._watchers = []const opts = vm.$optionsif (opts.props) initProps(vm, opts.props)if (opts.methods) initMethods(vm, opts.methods)if (opts.data) {initData(vm)} else {observe(vm._data = {}, true /* asRootData */)}if (opts.computed) initComputed(vm, opts.computed)if (opts.watch && opts.watch !== nativeWatch) {initWatch(vm, opts.watch)}
}

在initState中,initData做了两件事:
1.将data中的属性都挂载到vm上去,方便后面以this.xx访问data里的变量
2.则是通过observe函数对定义的data对象进行数据劫持,在observe的过程中,会判断属性是对象还是数组,
如果是对象:将对象的每个属性添加getter,setter函数,每个属性都拥有自己的一个dep实例对象(dep实例对象相当于是被观察者的一个筐,里面装了有哪些watcher在观察它);在getter方法里,会收集依赖,也就是存储watcher实例,同时watcher实例也会存储dep实例;在setter方法里,会通知这些watcher实例来更新依赖。
如果是数组:数组的话是通过增强数组七个方法的原型方法,当访问数组上面那七个方法的时候会被拦截,以此来实现响应式。

这时候你可能会问,那get方法是如何被触发的呢?
如果要触发get方法,那么说明有地方在访问这个属性,有哪些地方会访问属性并要对之做出改变呢?
答案是computed、watcher、template;
1.在初始化computed的时候,会对每一个computed属性生成一个watcher,并且会传一个参数lazy:true,表明这个watcher是惰性的;
2.在初始化watch的时候,和computed类似,只是没有传lazy参数
3.在编译模版的时候,会生成render函数,render函数执行的时候会去获取变量值,获取变量值的时候就会触发get,收集依赖。

这就对应了三个watcher,computed watcher;普通watcher;render watcher。

http://www.lryc.cn/news/696.html

相关文章:

  • 服务调用分布式session
  • Maven知识点-插件-maven-surefire-plugin简介
  • 如何借力Alluxio推动大数据产品性能提升与成本优化?
  • linux shell脚本被包含是什么意思?.命令和source命令(在脚本中运行脚本,脚本中调用脚本)(脚本包含,父子脚本)
  • MySQL进阶篇之锁(lock)
  • TMDSEVM6657LS评估板恢复出厂默认状态
  • 聊一聊,我对DDD的关键理解
  • 算法笔记(一)—— 认识复杂度和简单排序算法
  • MQ消息中间件常见题及解决办法
  • 网关服务限流熔断降级分布式事务
  • JVM——7JVM调优实战及常量池详解
  • 子串分值【第十一届】【省赛】【A组】
  • SpringCloud 中 Config、Bus、Stream、Sleuth
  • Quantum 构建工具使用新的 TTP 投递 Agent Tesla
  • 浏览器中的 JavaScript 执行机制
  • kafka集群搭建及问题
  • 不要忽视web渗透测试在项目中起到的重要性
  • Early Stopping中基于测试集(而非验证集)上的表现选取模型的讨论
  • appium ios真机自动化环境搭建运行(送源码)
  • 米尔基于ARM嵌入式核心板的电池管理系统(BMS)
  • Java后端项目IDEA配置代码规范检查,使用checkStyle实现
  • Nginx_4
  • linux Ubuntu KUbuntu 系统安装相关
  • 个人信息保护认证
  • Negative Prompt in Stable Diffusion
  • MLX90316KGO-BDG-100-RE传感器 旋转位置 角度测量
  • Reflections反射包在springboot jar环境下扫描不到class排查过程
  • 黑马】后台项目171集
  • Qt 5 架构和特点
  • 转换符说明使用方法(在printf函数中)