Vue源码:数据响应式原理

文章目录

概述

在vue中,我们可以通过改变data内的数据属性,从而对应的视图组件也会产生更新,这涉及到了vue的数据响应式原理。其机制主要是通过数据劫持结合发布订阅模式来实现。

数据劫持

这里主要是说vue2.0的劫持方式,通过Object.defineProperty方法来对data内属性的getter、setter方法进行劫持

发布订阅

多个订阅者观察同一个目标,若目标内对应使用过的数据发生更改,则通知对应的订阅者调用自生更新方法进行更新


流程

Vue源码:数据响应式原理

此图为按个人理解画的流程图,如有不对,欢迎指正。

observe:用于判断数据是否为对象,以及内部是否含有__ob__属性(为Observer的实例对象),如果没有则去new Observer产生实例。
Observer:观察目标。若传入的对象为数组类型,则将对应数组的原型通过setPrototypeOf指向重写好的arrayMethods
defineReactive:内部通过Object.defineProperty来劫持数据的getter、setter方法
Watcher:观察者。观察者内部若使用了观察目标的某一数据属性,则会产生全局标识并调用其getter方法,通过这个全局标识然后将当前观察者加入观察者依赖Dep。
Dep:内部含有subs数组,保存了所有观察者。一旦数据发生更改,调用了setter方法,则会去通知更新。

注意:
由于Object.defineProperty无法监听数组变化,所以这里通过重写了的数组的七个方法(push、pop、unshift、shift、splice、reverse、sort)于arrayMethods中,这里arrayMethods的原型是Array.prototype

详细代码

上一篇:对象中的boolean类型属性添加@Data没有getter和setter


下一篇:编程细节整理