vue响应式原理 (响应式并不等于数据双向绑定,千万不要混淆)

vue实现数据双向绑定主要是:采用数据劫持结合发布者-订阅者模式的方式,通过 Object.defineProperty() 数据劫持,来劫持各个属性的setter,getter,在数据更新时发布消息给订阅者,触发相应监听回调。

当把一个普通 Javascript 对象传给 Vue 实例来作为它的 data 选项时,Vue 将遍历它的属性,用 Object.defineProperty() 将它们转为 getter/setter。用户看不到 getter/setter,但是在内部它们让 Vue 追踪依赖,在属性被访问和修改时通知变化。

vue的数据双向绑定 将MVVM作为数据绑定的入口,整合Observer,Compile和Watcher三者,通过Observer来监听自己的model的数据变化,通过Compile来解析编译模板指令(vue中是用来解析 {{}}),

最终利用watcher搭起observer和Compile之间的通信桥梁,达到数据变化 —>视图更新;视图交互变化(input)—>数据model变更双向绑定效果。

1、Object.defineProperty()  (Observer 监听model数据变化)

语法: Object.defineProperty(obj, prop, descriptor)
obj:要定义的对象
prop:要定义的对象的属性
descriptor:要定义或修改的属性描述符。

 

 

2、订阅-发布者模式 (watcher)

订阅模式其实就是就是一个队列,我们把需要执行的函数推进一个数组,在需要用的时候依次去执行这个数组中方法

订阅就是把函数PUSH到数组,

发布就是便利执行这些函数

 

 3、compile 模板编译

vue模板编译其实就是把 template 模板编译成浏览器可识别的 HTML 

具体原理参考博文:https://segmentfault.com/a/1190000012922342

原文地址:https://www.cnblogs.com/xxflz/p/14134080.html