Vue.js 的响应式原理是其核心特性之一,使得数据变化能够自动更新到视图。Vue 的响应式系统主要依赖于 Object.defineProperty(在 Vue 2.x 中)和 Proxy(在 Vue 3.x 中)来实现数据的观察和更新。以下是对 Vue 响应式原理的详细解释。

1. Vue 2.x 的响应式原理

在 Vue 2.x 中,Vue 使用 Object.defineProperty 来实现数据的响应式。

1.1 数据劫持

当 Vue 实例被创建时,它会遍历 data 对象的所有属性,并使用 Object.defineProperty 将每个属性转换为 getter 和 setter。这样,当属性被访问或修改时,Vue 可以执行相应的逻辑。

function defineReactive(obj, key, val) {const dep = new Dep(); // 创建一个依赖收集器// 递归处理嵌套对象let childOb = observe(val);Object.defineProperty(obj, key, {enumerable: true,configurable: true,get() {// 添加依赖if (Dep.target) {dep.depend(); // 依赖收集if (childOb) {childOb.dep.depend(); // 处理数组的依赖}}return val;},set(newVal) {if (newVal === val) return;val = newVal;childOb = observe(newVal); // 处理新值的响应式dep.notify(); // 通知所有依赖更新}});
}
1.2 依赖收集

当组件渲染时,Vue 会将当前的渲染 watcher 作为 Dep.target 存储。每当访问一个响应式属性时,getter 会被调用,依赖会被收集到 Dep 中。

1.3 触发更新

当属性的 setter 被调用时,Vue 会通知所有依赖于该属性的 watcher 进行更新。这样,视图就会自动更新。

2. Vue 3.x 的响应式原理

在 Vue 3.x 中,Vue 使用 Proxy 来实现响应式,提供了更强大的功能和更好的性能。

2.1 使用 Proxy

Proxy 可以直接监听对象的所有操作(如读取、写入、删除等),而不需要逐个属性地定义 getter 和 setter。

function reactive(target) {return new Proxy(target, {get(target, key, receiver) {// 依赖收集const res = Reflect.get(target, key, receiver);track(target, key); // 依赖收集return res;},set(target, key, value, receiver) {const oldValue = target[key];const result = Reflect.set(target, key, value, receiver);if (oldValue !== value) {trigger(target, key); // 触发更新}return result;}});
}
2.2 依赖收集与触发更新

在 Vue 3.x 中,依赖收集和触发更新的逻辑被封装在 tracktrigger 函数中。track 函数用于收集依赖,而 trigger 函数用于通知依赖更新。

3. 响应式系统的优缺点

优点
  • 自动更新:数据变化时,视图会自动更新,减少了手动 DOM 操作的复杂性。
  • 高效:Vue 3.x 的 Proxy 实现比 Vue 2.x 的 Object.defineProperty 更高效,能够处理更复杂的对象结构。
缺点
  • 性能开销:在大量数据变化时,依赖收集和更新可能会带来性能开销。
  • 限制:Vue 2.x 中,Object.defineProperty 无法监听数组的变化(如数组的索引和长度),而 Vue 3.x 的 Proxy 则可以更好地处理这些情况。

4. 总结

Vue 的响应式原理通过数据劫持和依赖收集,使得数据变化能够自动反映到视图上。Vue 2.x 使用 Object.defineProperty 实现响应式,而 Vue 3.x 则使用 Proxy,提供了更强大的功能和更好的性能。理解这些原理有助于更好地使用 Vue 进行开发,并优化应用的性能。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/web/92164.shtml
繁体地址,请注明出处:http://hk.pswp.cn/web/92164.shtml
英文地址,请注明出处:http://en.pswp.cn/web/92164.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【AI论文】PixNerd:像素神经场扩散

摘要:扩散变换器目前所取得的成功在很大程度上依赖于预训练变分自编码器(VAE)所塑造的压缩潜在空间。然而,这种两阶段训练模式不可避免地会引入累积误差和解码伪影。为解决上述问题,研究人员选择回归像素空间&#xff…

Java中的LambdaMetafactory:动态生成Lambda的底层黑魔法

引言 在Java 8中,Lambda表达式作为最引人注目的新特性之一被引入。但你是否曾好奇过,这些简洁的Lambda表达式在底层是如何实现的?这就是LambdaMetafactory发挥作用的地方。作为Java语言中一个不太为人所知但极其重要的类,LambdaMe…

看不见的伪造痕迹:AI时代的鉴伪攻防战

在生成式人工智能飞速发展的今天,“眼见为实”这句话的有效性正面临前所未有的挑战。以往,图像篡改往往通过传统的图像处理工具(如 Photoshop)进行,需要较高的技术门槛和人工成本;而现在,仅需通…

《React+TypeScript实战:前端状态管理的安全架构与性能优化深解》

当用户在界面上进行表单提交、数据筛选等操作时,每一次交互的精准响应,都依赖于底层状态架构对风险的预判与性能的调控。深入理解如何在功能实现之外,构筑一套兼顾状态安全与运行高效的体系,是从基础开发迈向工程化实践的关键一跃。状态管理机制的设计,需要穿透“数据更新…

【android bluetooth 协议分析 01】【HCI 层介绍 30】【hci_event和le_meta_event如何上报到btu层】

一、引言 在蓝牙协议栈中,HCI Event 和 LE Meta Event 是控制器(Controller)向主机(Host)报告事件的两种形式,它们属于 HCI(Host Controller Interface)层。这是主机和控制器之间通…

小实验--震动点灯

1.实验目的 使用中断的方法,震动传感器检测到震动时,LED1点亮2秒,之后熄灭。 2.硬件清单 震动传感器STM32开发板ST-Link 3.硬件连接STM32震动传感器PA4DO3V3VCCGNDGND4.代码 4.1exti.c #include "exti.h" #include "sys.h&quo…

vcpkg: 一款免费开源的C++包管理器

目录 1.简介 2.安装 3.常用命令 4.与项目集成 5.vcpkg的工作原理 5.1.包索引:ports 系统(定义库的 “元信息”) 5.2.源码获取:从 “地址” 到 “本地缓存” 5.3.编译构建:按 “triplet” 定制目标 5.4.安装布…

WinCC通过无线Modbus TCP监控S7-1200/200SMT PLC实例详解

工业自动化系统中,车间内通常部署多台PLC设备并需通过中央监控平台实现集中管控。考虑到工业现场设备间距普遍在数十至数百米范围,传统有线以太网虽能保障传输速率,但其施工需面临电缆沟开挖或复杂布线工程,既增加线材采购、人力投…

【AI智能编程】Trae-IDE工具学习

什么是Trae? Trae与 AI 深度集成,提供智能问答、代码自动补全以及基于 Agent 的 AI 自动编程能力。使用 Trae 开发项目时,你可以与 AI 灵活协作,提升开发效率。提供传统的 IDE 功能,包括代码编写、项目管理、插件管理…

智能驾驶再提速!批量苏州金龙L4级自动驾驶巴士交付杭州临平区

近日,由苏州金龙海格客车研发的“清源”L4级自动驾驶巴士现身杭州市临平区并投入测试。这是临平区引进的首批L4级自动驾驶巴士,标志着临平区智能交通建设迈入新阶段。此次投入测试的“清源”小巴采用一级踏步设计,车身延续了海格蔚蓝巴士的经…

Spring_事务

在mysql阶段的文章中,已经介绍过事务了。本篇文章是对mysql事务的总结和对使用Spring框架来实现事务操作的讲解。事务回顾什么是事务事务时一组操作的集合,是一个不可分割的操作。事务会把所有操作作为一个整体,一起向数据库提交或者撤销操作…

事务管理介绍

为什么要用事务管理在我们同时操作两个或更多个数据库时,可能因为网络等各方面原因导致中间出现异常。造成像对第一个数据库的操作成功了,但是对第二个数据库的操作没有成功。这样数据的完整性就被破坏了。事务:是一组操作的集合,…

Android 之 ViewBinding 实现更安全、高效的视图绑定

​​一、配置说明​​​​作用位置​​需在模块级 build.gradle或 build.gradle.kts文件的 android {}块内添加:android {buildFeatures {viewBinding true // Kotlin DSL 语法} }android {buildFeatures {viewBinding true // Groovy 语法} }​​生成规则​​为每…

全球首款Java专用AI开发助手实测:一句话生成完整工程代码——飞算 JavaAI

🌟 嗨,我是Lethehong!🌟🌍 立志在坚不欲说,成功在久不在速🌍🚀 欢迎关注:👍点赞⬆️留言收藏🚀🍀欢迎使用:小智初学计算机…

Shader开发(七)创建第一个Shader项目

在前面的章节中,我们已经了解了Shader的基本概念和渲染管线的工作原理。现在,是时候动手实践了!本章将带您一步步创建第一个Shader项目,开启真正的Shader开发之旅。 为什么选择openFrameworks? 与其他文章不同&#x…

IAR软件中测量函数执行时间

通常在调试代码中需要直到某个函数或者某段代码的实际执行时间,在IAR中可以直接借助软件提供的工具来计算代码执行时间。 第一种方法 进入仿真调试界面,在需要测量的代码前面打断点。工具栏中选择 ST-LINK — Data Log Summary在 Data Log Summary 窗口中…

Java 字节码文件(.class)的组成详解

文章目录基础信息常量池字段方法属性字节码文件内容说明案例文件基本信息类的基本信息常量池字段信息构造方法实例方法主方法源文件信息字节码文件由五部分组成,分别是基础信息、常量池、字段、方法、属性。案例: public class Main implements Interfa…

C++之vector类的代码及其逻辑详解 (下)

1. insert()这个就是在指定位置插入一个元素,首先计算要插入的这个位置和开头之间的距离,接着判断那个_finish 有没有碰到_endofstorage 或者_endofstorage 是不是为0,如果满足条件,那就进行扩容,然后接着重新计算距离…

【自动化测试】Python Selenium 自动化测试元素定位专业教程

1. 引言:元素定位在 Selenium 中的核心地位 元素定位是 Selenium 自动化测试的基础,所有用户交互操作(如点击、输入、选择)都依赖于准确识别页面元素。Selenium WebDriver 提供了多种定位策略,从简单的 ID 定位到复杂…

通用代码自用

多文件上传public int save(Role role, RequestParam("nfile") MultipartFile nfile, HttpServletRequest request) {System.out.println(nfile.getOriginalFilename());String path request.getSession().getServletContext().getRealPath("/upload");Fi…