在vue中,我们可以通过改变data内的数据属性,从而对应的视图组件也会产生更新,这涉及到了vue的数据响应式原理。其机制主要是通过数据劫持结合发布订阅模式来实现。
这里主要是说vue2.0的劫持方式,通过Object.defineProperty方法来对data内属性的getter、setter方法进行劫持
多个订阅者观察同一个目标,若目标内对应使用过的数据发生更改,则通知对应的订阅者调用自生更新方法进行更新
此图为按个人理解画的流程图,如有不对,欢迎指正。
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
详细代码