当前位置: 首页 > news >正文

vue3 reactive响应式实现源码

Vue 3 的 reactive 是基于 JavaScript 的 Proxy 实现的,因此它通过代理机制来拦截对象的操作,从而实现响应式数据的追踪。下面是 Vue 3 的 reactive 源码简化版。

Vue 3 reactive 源码简化版

首先,我们需要了解 reactive 是如何工作的,核心的功能是使用 Proxy 来代理对象并处理对象的读取和修改。

// reactive.js
export function reactive(target) {// 检查 target 是否是对象if (typeof target !== 'object' || target === null) {return target;}// 使用 Proxy 来代理对象的读取和设置操作return new Proxy(target, {get(target, prop, receiver) {// 当访问对象的属性时,执行 getter// 可以在此处添加追踪操作,比如收集依赖console.log(`Getting ${String(prop)}:`, target[prop]);return target[prop];},set(target, prop, value, receiver) {// 当设置对象的属性时,执行 setter// 可以在此处添加更新操作,比如通知视图更新console.log(`Setting ${String(prop)} to:`, value);target[prop] = value;// 返回 true 表示修改成功return true;}});
}

关键点解释

  • ProxyProxy 是 JavaScript 的一项新特性,它允许我们定义自定义的行为来拦截对象的基本操作(如读取、写入、删除等)。在 reactive 的实现中,Proxy 拦截了对象的 getset 操作。

  • get:当访问对象的某个属性时,会触发 get 方法。在 get 方法中,我们通常会做两件事:

    • 追踪依赖:在 Vue 中,通常会使用依赖收集来追踪视图中对数据的引用。
    • 返回属性值:最终返回目标对象的属性值。
  • set:当设置对象的某个属性时,会触发 set 方法。在 set 方法中,我们通常会做以下几件事:

    • 修改目标对象的属性值。
    • 通知视图或其他相关部分进行更新。

完整实现(简化版)

下面是一个简化版的 Vue 3 reactive 源码,它展示了如何通过 Proxy 来实现响应式。

// reactive.js
function reactive(target) {if (typeof target !== 'object' || target === null) {return target;}const handler = {get(target, prop, receiver) {// 在这里,通常会收集依赖项// 例如,Vue 通过某种方式追踪当前访问的属性console.log(`Getting ${String(prop)}:`, target[prop]);return target[prop];},set(target, prop, value, receiver) {// 在这里,可以触发视图更新的机制console.log(`Setting ${String(prop)} to:`, value);target[prop] = value;// 返回 true,表示操作成功return true;}};return new Proxy(target, handler);
}// 使用例子
const state = reactive({count: 0,user: { name: 'John' }
});state.count = 1;  // 输出: Setting count to: 1
console.log(state.count);  // 输出: Getting count: 1

Vue 3 实现中的关键点

在 Vue 3 中,reactive 会结合 Vue 的内部系统来做更复杂的事情,比如:

  1. 依赖收集:当属性被读取时,Vue 会通过 get 拦截器收集依赖。这意味着,只有当属性真正被访问时,相关组件才会注册为该属性的依赖。

  2. 视图更新:当数据发生变化时,set 方法会触发视图更新,通常是通过通知渲染函数重新执行来实现的。

  3. 嵌套对象的响应式:当你访问一个对象的属性时,Vue 会递归地将嵌套对象也变成响应式对象。

完整版源码(源码中包含 Vue 的依赖管理和优化)

如果你想查看 Vue 3 reactive 和其他响应式 API(如 ref)的完整实现,可以参考 Vue 3 的源码库,具体代码位于 packages/reactivity 文件夹下。

你可以从 Vue 3 GitHub 仓库 下载完整的源码。

具体的 reactive 实现代码会涉及更多的优化和功能,比如依赖追踪、缓存、代理标识符等复杂逻辑,建议直接查看 Vue 3 的源码进行深入学习。

相关文章:

vue3 reactive响应式实现源码

Vue 3 的 reactive 是基于 JavaScript 的 Proxy 实现的,因此它通过代理机制来拦截对象的操作,从而实现响应式数据的追踪。下面是 Vue 3 的 reactive 源码简化版。 Vue 3 reactive 源码简化版 首先,我们需要了解 reactive 是如何工作的&…...

git的使用(简洁版)

什么是 Git? Git 是一个分布式版本控制系统 (DVCS),用于跟踪文件的更改并协调多人之间的工作。它由 Linus Torvalds 在 2005 年创建,最初是为了管理 Linux 内核的开发。Git 的主要目标是提供高效、易用的版本控制工具,使得开发者…...

使用命令行创建 Maven 项目

本指南将引导您通过命令行创建一个简单的 Maven 项目。本教程假设您已经在您的机器上安装了 Maven 和 JDK 21。 第一步:验证 Maven 和 Java 安装 在开始之前,我们需要验证 Maven 和 Java 是否已正确安装在您的系统上。 验证 Maven 安装 打开命令行终…...

JVM_栈详解一

1、栈的存储单位 **栈中存储什么?**, 每个线程都有自己的栈,栈中的数据都是以栈帧(Stack Frame)的格式存在。在这个线程上正在执行的每个方法都各自对应一个栈帧(Stack Frame)。 栈帧是一个内存…...

Linux 金仓数据库安装和使用

文章目录 Linux 金仓数据库安装和简单使用 一、下载二、安装三、启动法1. 通用启动方式法2. 系统服务启动方式 四、测试五、DB管理工具1. 启动DB管理工具2. DB管理工具的常用功能 六、卸载 Linux 金仓数据库安装和简单使用 一、下载 打开官网 https://www.kingbase.com.cn/xzz…...

STM32笔记(串口IAP升级)

一、IAP简介 IAP(In Application Programming)即在应用编程, IAP 是用户自己的程序在运行过程中对 User Flash 的部分区域进行烧写,目的是为了在产品发布后可以方便地通过预留的通信口对产 品中的固件程序进行更新升级。 通常实…...

C++网络编程:select IO多路复用及TCP服务器开发

C网络编程:使用select实现IO多路复用 一、什么是 IO 多路复用?二、IO多路复用器 select三、相关接口3.1、fd_set 结构体3.2、宏和函数 四、select 实现 TCP 服务器五、总结 一、什么是 IO 多路复用? 在网络编程中,最容易想到的并…...

部署 L2JMobius 天堂2芙蕾雅版本

首先下载所需要的服务器端 “L2J_Mobius.zip” 和芙蕾雅客户端(三个压缩文件), 我的网盘下载:https://pan.baidu.com/s/1XdlcCFPvXnzfwFoVK7Sn7Q?pwdavd4 所有文件都在“芙蕾雅”目录下,也可以加入企鹅交流裙 87470…...

C#开发合集

用C#轻松搞定m3u8视频下载与合并 嘿,程序员们!今天咱们来聊聊如何用C#写个小程序,轻松下载和合并m3u8视频文件。没错,就是那种分段的流媒体视频。准备好了吗?让我们开始吧! 准备工作 在动手之前&#xf…...

鸿蒙面试 --- 性能优化

性能优化可以从三个方面入手 感知流畅、渲染性能、运行性能 感知流畅 在应用开发中,动画可以为用户界面增添生动、流畅的交互效果,提升用户对应用的好感度。然而,滥用动画也会导致应用性能下降,消耗过多的系统资源,…...

React的基础知识:Context

1. Context 在 React 中,Context 提供了一种通过组件树传递数据的方式,无需手动在每个层级传递 props。这在处理一些全局应用状态时非常有用,比如用户认证、主题、语言偏好等。 如何使用 Context 创建 Context:首先,…...

微知-lspci访问到指定的PCIe设备的几种方式?(lspci -s bus;lspci -d devices)

通过bdf号查看 -s (bus) lspci -s 03:00.0通过vendor id或者device id等设备查看 -d (device) lspci -d 15b3: #这里是vendor号,所以在前面 lspci -d :1021 #这里是设备号,所以要:在前vendorid和deviceid…...

【Kubernetes 集群核心概念:Pod】pod生命周期介绍【五】

5.1 Pod生命周期 Pod的生命周期指的是从Pod创建到终止的整个过程。它分为以下两种常见情况: 长期运行Pod: 例如运行HTTP服务的Pod,它在正常情况下会一直运行,但可以手动删除或终止。短期运行Pod: 例如执行计算任务的…...

c++的虚继承说明、案例、代码

虚继承的基本概念 在 C 中,虚继承主要用于解决多继承时可能出现的菱形继承问题。菱形继承是指一个类有两个(或更多)子类,而这两个子类又同时继承自一个共同的基类,当这些子类又被另一个类继承时,就形成了菱…...

小米PC电脑手机互联互通,小米妙享,小米电脑管家,老款小米笔记本怎么使用,其他品牌笔记本怎么使用,一分钟教会你

说在前面 之前我们体验过妙享中心,里面就有互联互通的全部能力,现在有了小米电脑管家,老款的笔记本竟然用不了,也可以理解,毕竟老款笔记本做系统研发的时候没有预留适配的文件补丁,至于其他品牌的winPC小米…...

介绍SSD硬盘

SSD硬盘(固态硬盘,Solid State Drive)是一种利用闪存技术存储数据的存储设备,与传统的机械硬盘(HDD)不同,SSD没有任何活动部件,因此其性能和耐用性较为优越。以下是SSD硬盘的一些主要…...

CMAKE常用命令详解

NDK List基本用法 Get–获取列表中指定索引的元素 list(Get list_name index output_var)解释 list_name: 要操作集合的名称index: 要取得的元素下标output_var: 保存从集合中取得元素的结果 栗子 list(GET mylist 0 first_element) # 获取第一个元素APPEND–在列表末尾…...

Vue3的通灵之术Teleport

前言 近期Vue3更新了一些新的内容&#xff0c;我都还没有一个一个仔细去看&#xff0c;但是还是有必要去解读一下新内容的。就先从Teleport 开始吧。 官方对 Teleport 的解释是&#xff1a;<Teleport> 是一个内置组件&#xff0c;它可以将一个组件内部的一部分模板“传…...

ue5第三人称闯关游戏学习(一)

视频资料38 - Compilers and Editors_哔哩哔哩_bilibili 上一个第一人称射击项目做完 接下来要更深入学习。 引入资产与C来创建第三人称闯关游戏 这次要引入的资产有两个分别是 Unreal Learning Kit&#xff1a;Game和stylized character kit: casual 01 不过有个比较麻…...

IIC 随机写+多次写 可以控制写几次

verilog module icc_tx#(parameter SIZE 2 , //用来控制写多少次 比如地址是0000 一个地址只能存放8bit数据 超出指针就会到下一个地址0001parameter CLK_DIV 50_000_000 ,parameter SPEED 100_000 ,parameter LED 50 )( input wire c…...

开发预告:关于改造Hermes-agent这件事,我想说的比上一篇多得多

先声明一点&#xff1a;这不是什么技术布道&#xff0c;更不是产品软文。这篇文章里写的东西&#xff0c;要么是我花了真金白银和睡眠时间换来的&#xff0c;要么是我接下来要去踩的坑。你要觉得哪里不对&#xff0c;直接怼。你要觉得哪里说到你心坎里了&#xff0c;欢迎一起搞…...

Arm CoreLink CMN-600硬件错误解析与解决方案

1. Arm CoreLink CMN-600硬件错误深度解析在复杂SoC设计中&#xff0c;互连架构的质量直接决定整个系统的稳定性和性能。作为Arm Neoverse平台的核心组件&#xff0c;CoreLink CMN-600&#xff08;Coherent Mesh Network&#xff09;承担着处理器集群、内存控制器和I/O设备之间…...

掌握高效窗口管理:专业级分辨率调整工具完全指南

掌握高效窗口管理&#xff1a;专业级分辨率调整工具完全指南 【免费下载链接】SRWE Simple Runtime Window Editor 项目地址: https://gitcode.com/gh_mirrors/sr/SRWE 在当今多任务处理和多屏工作环境中&#xff0c;你是否经常遇到窗口大小不合适、分辨率限制或游戏画面…...

告别调参焦虑!用Matlab Regression Learner App快速搞定你的第一个回归模型(附三维曲面拟合实战)

告别调参焦虑&#xff01;用Matlab Regression Learner App快速搞定你的第一个回归模型&#xff08;附三维曲面拟合实战&#xff09; 在科研和工程领域&#xff0c;数据建模是绕不开的核心技能。但传统建模流程往往令人望而生畏&#xff1a;从数据清洗到特征工程&#xff0c;从…...

C语言编写轻量爬虫工具

当我们要使用C语言编写一个定制化轻量爬虫工具&#xff0c;得需要结合网络请求、HTML解析和数据处理等步骤。由于是轻量级&#xff0c;正常情况下我们将使用C语言标准库以及一些第三方库来简化开发。这样省时省力&#xff0c;生态丰富可以帮助大家少走很多弯路。具体细节可以看…...

开源量化分析平台Fin-Maestro:十大核心模块构建个人交易决策系统

1. 项目概述&#xff1a;一个为独立交易者打造的量化分析工具箱 如果你和我一样&#xff0c;在股票和加密货币市场里摸爬滚打了好些年&#xff0c;那你一定经历过这样的阶段&#xff1a;面对海量的K线图、财务数据和市场新闻&#xff0c;感觉信息过载&#xff0c;决策时总是犹…...

MiGPT终极指南:如何将小爱音箱改造成AI语音助手

MiGPT终极指南&#xff1a;如何将小爱音箱改造成AI语音助手 【免费下载链接】mi-gpt &#x1f3e0; 将小爱音箱接入 ChatGPT 和豆包&#xff0c;改造成你的专属语音助手。 项目地址: https://gitcode.com/GitHub_Trending/mi/mi-gpt 在智能家居日益普及的今天&#xff0…...

浏览器高阶使用指南:从基础操作到效率系统构建

1. 项目概述&#xff1a;浏览器&#xff0c;远不止是“上网”那么简单“abczsl520/browser-use-skill”这个项目名&#xff0c;乍一看可能会觉得有点“标题党”——浏览器使用技巧&#xff1f;这谁不会啊&#xff1f;点开、输入网址、回车&#xff0c;不就完了吗&#xff1f;如…...

Excel高效使用技巧(十五):终极技巧汇总:高级玩家必备的邪修操作

“Excel的终极奥义,不是你会多少公式,而是你知道多少’不该用Excel’的时刻,以及如何优雅地让Excel和其他工具联动。” —— 卡兹克 前言:你的Excel到达哪个段位? 经过十四篇文章的洗礼,你现在应该已经掌握了: 数据清洗:Power Query玩得飞起 数据分析:透视表+DAX不在…...

sdd-riper:专业磁盘镜像工具在数据恢复中的原理与实践

1. 项目概述与核心价值最近在整理一些老旧存储设备时&#xff0c;遇到了一个挺典型的问题&#xff1a;手头有几块年代久远的硬盘&#xff0c;里面可能还存着一些早年间的照片、文档&#xff0c;但硬盘本身已经不太稳定&#xff0c;系统里能识别&#xff0c;但拷贝文件时动不动就…...