其他分享
首页 > 其他分享> > vue实现数据双向绑定的原理:Object.defineProperty()

vue实现数据双向绑定的原理:Object.defineProperty()

作者:互联网

vue实现数据双向绑定的原理:Object.defineProperty()

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更新双向绑定效果。

标签:vue,Object,绑定,双向,defineProperty,数据
来源: https://blog.csdn.net/qq_46177396/article/details/123086512