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