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-12-23【JS逆向百例】爱疯官网登录逆向分析
- 2024-12-21Vue3教程:新手入门到实践应用
- 2024-12-21VueRouter4教程:从入门到实践
- 2024-12-20Vue3项目实战:从入门到上手
- 2024-12-20Vue3项目实战:新手入门教程
- 2024-12-20VueRouter4项目实战:新手入门教程
- 2024-12-20如何实现JDBC和jsp的关系?-icode9专业技术文章分享
- 2024-12-20Vue项目中实现TagsView标签栏导航的简单教程
- 2024-12-20Vue3入门教程:从零开始搭建你的第一个Vue3项目
- 2024-12-20从零开始学习vueRouter4:基础教程