Vue源码:数据响应式原理
2021/10/25 22:10:27
本文主要是介绍Vue源码:数据响应式原理,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
文章目录
- 概述
- 数据劫持
- 发布订阅
- 流程
概述
在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
详细代码
这篇关于Vue源码:数据响应式原理的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-16Vue3资料:新手入门必读教程
- 2024-11-16Vue3资料:新手入门全面指南
- 2024-11-16Vue资料:新手入门完全指南
- 2024-11-16Vue项目实战:新手入门指南
- 2024-11-16React Hooks之useEffect案例详解
- 2024-11-16useRef案例详解:React中的useRef使用教程
- 2024-11-16React Hooks之useState案例详解
- 2024-11-16Vue入门指南:从零开始搭建第一个Vue项目
- 2024-11-16Vue3学习:新手入门教程与实践指南
- 2024-11-16Vue3学习:从入门到初级实战教程