理解VUE响应式原理[通俗易懂]

理解VUE响应式原理[通俗易懂]1、响应式原理基础响应式原理基础是基于Object.defineProperty(obj,prop,descriptor),descriptor里面可以定义get和set方法,可以在获取属性值事触发get方法(可以收集依赖),设置属性值时触发set方法(更新依赖)。扩展:上面是vue2.0的基础原理,vue3.0的基础原理是:2、核心对象:Dep与WatcherDep:vue在data里申明的每一个属性都会生成一个Dep的实例对象,De…

大家好,又见面了,我是你们的朋友全栈君。

1、响应式原理基础

        响应式基本原理是基于Object.defineProperty(obj, prop, descriptor), descriptor里面可以定义get和set方法,可以在获取属性值事触发get方法(可以收集依赖),设置属性值时触发set方法(更新依赖)。

        扩展:上面是vue2.0的响应式基本原理,vue3.0的基本原理是Proxy,可以监听属性的get和set方法,监听属性的添加和删除等等,比Object.defineProperty能力更强,但是不兼容IE11。

2、核心对象:Dep与Watcher

        Dep: vue在data里申明的每一个属性都会生成一个Dep的实例对象,Dep.subs存储着当该属性变化时需要去更新的Watcher;

        Watcher: 有3种情况会生成Watcher的实例对象,分别为:

  1.  定义在computed里的计算属性;
  2. 在watch里写的监听函数;
  3. 组件的渲染Watcher;

3、收集依赖与更新依赖

3.1 收集依赖

        将Watcher的实例对象w分发到它所依赖的属性的Dep中,过程如下:

  1. 将Dep.target = 当前的Watcer 的实例对象w;
  2. w执行定义的函数(即在computed/watch写的函数);
  3. 执行函数的过程如果使用data里定义的属性,则会触发属性的get方法,get方法中Dep实例对象dep会将Dep.target中存储的w放入到dep.subs数组中,完成依赖收集。

    说明:Dep.target为当前Watcer的实例对象

3.2 更新依赖

        当修改我们申明的某个属性时,会触发属性的set方法,set方法会将dep.subs数组中收集的Watcher实例对象进行更新,即触发我们定义在computed和watch里面的函数。

4、源码调试

4.1 测试的页面代码

<template>
  <div>
    <div>a:<input v-model="a" /></div>
    <div>c:{
  
  { c }}</div>
    <div>b:<input v-model="b" /></div>
  </div>
</template>
<script>
export default {
  data: () => {
    return {
      a: '',
      b: ''
    }
  },
  computed: {
    c() {
      return 'source from ' + this.a;
    }
  },
  watch: {
    b() {
      console.log('b changed');
    }
  }
};
</script>

上面的代码vue初始化后会生成如下几个对象:

1、对象说明

属性a和b对应的Dep实例对象(收集a、b改变需要更新的Watcher):depA、depB;

页面渲染函数生成对应的Watcher实例对象updateWatcher;

computed属性c生成对应的Watcher实例对象:watcherC;

watch监听属性b生成对应的Watcher实例对象:watcherB;

2、Dep与Watcher的关系

a、b变化页面需要重新渲染,所以updateWatcher存在于depA和depB的subs中;

计算属性c依赖属性a的变化更更新,所以watcherC存在于depA的subs中;

b的变化会触发定义watch 里b的监听函数,所以watcherB存在于depB的subs中;

3、最终的关系结果

最终属性a收集的依赖 depA.subs = [ updateWatcher,  watcherC];

最终属性b收集的依赖 depB.subs = [ updateWatcher,  watcherB];

4.2  源码调试

        找到源码文件:node_modules\vue\dist\vue.runtime.esm.js;

        4.2.1 主要涉及如下几个函数:

        1、收集依赖的入口函数:initState(页面初始化时执行);

        初始化顺序是先data–>computed–>watch:原因是computed依赖data, watch监听data和computed里的属性,被依赖的需要先初始化。

理解VUE响应式原理[通俗易懂]

        2、初始化computed和watch时,生成Watcher实例化对象

              先执行Watcher.get函数,将Dep.target = 当前Watcher实例化对象

理解VUE响应式原理[通俗易懂]

理解VUE响应式原理[通俗易懂]

        触发收集依赖

理解VUE响应式原理[通俗易懂]

执行计算属性里面的函数,如果访问到data中的某个属性时,会触发data属性的get方法,触发依赖收集:

 理解VUE响应式原理[通俗易懂]

 当修改这个属性时会触发set方法,会触发更新dep.subs里面watcher对象

理解VUE响应式原理[通俗易懂]

最终触发Watcher的更新函数,将待更新的watcher放入队列中:

理解VUE响应式原理[通俗易懂]

4.2.2 computed属性特别说明

        computed属性在初始化initComputed之前还有一次更早的初始化,在调用createComponent函数生成vnode组件时,调用了Vue.extend –》defineComputed方法,并在组件的原型Prototype上添加computed里的计算属性,并声明为响应式属性,为何这样设计,原因不知,如有小伙伴知道,还请告知,谢谢

理解VUE响应式原理[通俗易懂]

理解VUE响应式原理[通俗易懂]

理解VUE响应式原理[通俗易懂]

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/132033.html原文链接:https://javaforall.net

(0)
上一篇 2022年4月30日 下午1:20
下一篇 2022年4月30日 下午1:40


相关推荐

  • Fleet问题

    Fleet问题1.  是否能自由部署fleetservices在1台或多台machine上。(可以指定部署1个服务在某台机器上,或者指定某个服务在多台机器上)

    2022年4月26日
    63
  • 驾考笔记:科目二考试满分攻略——超详细的点位细节梳理,各种意外情况处理方案整理

    驾考笔记:科目二考试满分攻略——超详细的点位细节梳理,各种意外情况处理方案整理前言 还记得去年听台湾大学的李宏毅老师讲他的宝可梦的时候 他谈到他至今没有去考驾照 因为他在等无人驾驶 当时笔者的感受是 我们可真是同道中人 作为无人驾驶的坚定拥护者 并且觉得自己未来还能为该领域的发展做出贡献的人 笔者的确有点 get 不到开车的乐趣 可现在终究是去学了 不是因为想赚学分 不是因为家长的劝导 更不是因为工作的需要 而是因为一个女孩 或许只有这样的理由才符合笔者放荡不羁的心性 还有两天考科二 笔者在这里梳理一下科二考试细节 算是一份笔记也算是一份记忆 如果你看到了它 并且其中的只言片语对你

    2026年3月20日
    2
  • 简单好玩的手机编程代码

    简单好玩的手机编程代码想学编程没有电脑 手机也能编程 为了让大家在任何时候都可以进行编程 这次给大家推荐四款手机编程 APP 让你不论在何时何地都可以化身码农 甚至暂时没有电脑 但是又想 Java AIDE 集成开发环境 AIDE 集成开发环境可以直接编译运行 Java 代码 同时还可以编写简单的安卓程序 支持自动补全 代码高亮 语法提示 程序猿老爸的高质量陪玩 造物粒子编程版科技小制作 小小工程师梦想萌芽编程也给他们带来了很多难得的品质 例如条理清晰逻辑性强 要知道一个简单前台功能的展现可能需要在后台编辑上百条代码 独立思考能力强

    2026年3月17日
    1
  • 回声状态网络ESN(含python、MATLAB代码数据)

    回声状态网络ESN(含python、MATLAB代码数据)时间序列预测 把获得的数据按时间顺序排序 分析其变化方向和程度 用来预测未来若干时期可能达到的水平 非线性自回归时间序列 特性是连续的观测数据比较长时间间隔的观测数据更具有相关性 e g Mackey Glass MG 时间序列 其表达式如下 回声状态网络 ESN EchoStateNet 可用于时间序列预测 由输入层 储备池 输出层构成 用一个储备池模式

    2026年3月26日
    2
  • 大数据开发常见面试问题总结「建议收藏」

    大数据开发常见面试问题总结「建议收藏」1、简述对大数据组件的理解?Yarn:大数据组件运行的job的管理器 Spark:分布式的利用内存进行分布式运算的大数据组件 Hbase:基于Hadoop的大数据常用数据库 Hive:基于Hadoop的大数据数据仓库,操作和关系型数据库(MySQL)类似2、hdfs文件系统中NameNode和DataNode的区别和联系?NameNode存储了元数据,并且调度,协调整个集群Da…

    2022年6月6日
    84
  • PHP开发WebaPP教程,开发webapp 需要什么技术基础吗? html5 js css3 PHP 除了这些还需要什么?…

    PHP开发WebaPP教程,开发webapp 需要什么技术基础吗? html5 js css3 PHP 除了这些还需要什么?…开发webapp需要什么技术基础吗?或者有没有开发webapp视频教程或者资料求推荐下回复内容:开发webapp需要什么技术基础吗?或者有没有开发webapp视频教程或者资料求推荐下数据库:比如mysqlSQL语言:对数据库编程的语言web容器:比如apache,nginx你还需要了解一些项目管理工具,如maven,svn,git等另外一些基础知识,如http、https协议等话说ap…

    2022年6月19日
    28

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号