Vue 之响应式原理(双向绑定)

Learn from codewhy

在Vue的动态双向绑定中,主要有两个需求,一个是监听数据变化,另一个是响应数据变化。具体分析如下

一览图
Vue 之响应式原理(双向绑定)

一、监听数据变化

Vue 内部 通过 Object.defineProperty 监听对象属性的改变

在 set 方法中监听属性值变化,在 get 方法中获取属性值
1、set 中
将监听到发生变化的数据告诉数据的使用者–>首先,要知道哪些人使用了这些数据,确定的方法:在解析 html 时,获取使用者信息–>如何获取到使用者信息呢:使用者要使用数据时会用到 get,这时就知道使用者信息了
Vue 之响应式原理(双向绑定)

二、响应新数据

Vue 响应变化数据通过发布者订阅者模式实现

subscribe 订阅,简写:subs
depend/dependence 依赖,简写:dep

1、原理分析–代码分析

发布者:
Vue 之响应式原理(双向绑定)
订阅者:
Vue 之响应式原理(双向绑定)
发布者通过 notify() 通知订阅者:
Vue 之响应式原理(双向绑定)

2、原理分析–上图分析

一个data属性对应一个dep对象,因为每个属性都有自己的订阅者sub

初始化:
Vue 之响应式原理(双向绑定)
更新后:
Vue 之响应式原理(双向绑定)

3、完整demo

只实现了单向绑定:DOM --> data,没有实现 data --> DOM

3.1 Vue 实例

Vue 之响应式原理(双向绑定)
代理:
Vue 之响应式原理(双向绑定)

3.2 Observer 类 – Object.defineProperty

observer 单词意思:观察者

在这里,实现发布者和订阅者之间的通信。在get方法中:addSub()添加订阅者,在set方法中:notify()通知订阅者
Vue 之响应式原理(双向绑定)

3.3 Dep 类 – 发布者:addSub(添加订阅者),notify(通知)

Vue 之响应式原理(双向绑定)

3.4 Compiler 类 – 处理 el(挂载的模块)

vm 是Vue实例
Vue 之响应式原理(双向绑定)
Compiler类内:解析node节点和节点内的属性(node.nodeType为1)、数据(node.nodeType==3)
Vue 之响应式原理(双向绑定)

【核心】双向绑定:

这里是 DOM --> data 的单向绑定
Vue 之响应式原理(双向绑定)
Compiler类外:正则表达式
Vue 之响应式原理(双向绑定)

3.5 Watcher 类 – 订阅者

vm:Vue实例
Vue 之响应式原理(双向绑定)


学习记录,如有错误,欢迎指正,by the way,当然,看源码是最好的学习方式,hahaha~~