ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

Vue源码:数据响应式原理

2021-10-25 22:00:37  阅读:185  来源: 互联网

标签:订阅 劫持 Vue 观察者 响应 源码 数组 数据 setter


文章目录

概述

在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,观察者,响应,源码,数组,数据,setter
来源: https://blog.csdn.net/qq_43522998/article/details/120952851

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有