| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> JavaScript知识库 -> 理解VUE响应式原理 -> 正文阅读 |
|
[JavaScript知识库]理解VUE响应式原理 |
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的实例对象,分别为:
3、收集依赖与更新依赖3.1 收集依赖????????将Watcher的实例对象w分发到它所依赖的属性的Dep中,过程如下:
? ??说明:Dep.target为当前Watcer的实例对象 3.2 更新依赖? ? ? ? 当修改我们申明的某个属性时,会触发属性的set方法,set方法会将dep.subs数组中收集的Watcher实例对象进行更新,即触发我们定义在computed和watch里面的函数。 4、源码调试4.1 测试的页面代码
上面的代码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; ? ? ? ? 主要涉及如下几个函数: ? ? ? ? 1、收集依赖的入口函数:initState(页面初始化时执行); ????????初始化顺序是先data-->computed-->watch:原因是computed依赖data, watch依赖data和watch,被依赖的需要先初始化。 ? ? ? ? 2、初始化computed和watch时,生成Watcher实例化对象 ? ? ? ? ? ? ? 先执行Watcher.get函数,将Dep.target = 当前Watcher实例化对象 ? ? ? ? 触发收集依赖 执行计算属性里面的函数,如果访问到data中的某个属性时,会触发data属性的get方法,触发依赖收集: ? ?当修改这个属性时会触发set方法,会触发更新dep.subs里面watcher对象 最终触发Watcher的更新函数,将待更新的watcher放入队列中: , |
|
JavaScript知识库 最新文章 |
ES6的相关知识点 |
react 函数式组件 & react其他一些总结 |
Vue基础超详细 |
前端JS也可以连点成线(Vue中运用 AntVG6) |
Vue事件处理的基本使用 |
Vue后台项目的记录 (一) |
前后端分离vue跨域,devServer配置proxy代理 |
TypeScript |
初识vuex |
vue项目安装包指令收集 |
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 | -2025/1/6 13:28:19- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |