vue2双向绑定原理

Posted aruanmei

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了vue2双向绑定原理相关的知识,希望对你有一定的参考价值。

大家都知道vue是mvvm模式,即model、view、viewmodel组成,viewmodel是搭建view、model的桥梁,监听数据的变化,通知对应的视图做更新。但具体是什么情况还是不太明白,明天要面试了,昨天看了一遍文章,里面有张图让我彻底明白了,一起看一下吧。

技术图片

 

简单来说,就是数据劫持+订阅发布实现,通过object.defineproperty()来劫持各属性的getter和setter,在数据变更时通知订阅者,触发相应的监听回调,实现视图更新。

 

详细点来讲,将mvvm作为数据绑定的入口,整合observer、compile、watcher。

对每个vue属性使用objecet.defineproperty()实现数据劫持,每个属性分配一个订阅者集合管理数组dep;

订阅者来自compile,一旦数据改变,通知watcher绑定更新函数,同时向dep添加订阅者;

当dep接到observer变化时,会想向watcher通知,watcher调用update()方法,触发compile绑定的回调,视图更新。

 

以上是关于vue2双向绑定原理的主要内容,如果未能解决你的问题,请参考以下文章

vue2.x双向数据绑定原理

面试题打卡第七天(vue2 vue3 原理篇)- 双向数据绑定

vue2和vue3数据双向绑定原理

Vue2.x 的双向绑定原理及实现

Vue双向绑定原理 从vue2的Object.defineProperty到vue3的proxy

vue2双向绑定原理