Vue 3 响应式对象:ref 和 reactive 的使用和区别

🎉🎉欢迎来到我的CSDN主页!🎉🎉
🏅我是尘缘,一个在CSDN分享笔记的博主。📚📚
👉点击这里,就可以查看我的主页啦!👇👇
尘缘的个人主页
🎁如果感觉还不错的话请给我点赞吧!🎁🎁
💖期待你的加入,一起学习,一起进步!💖💖

在这里插入图片描述

目录

  • 引言
  • 一、介绍
    • 1.1 Vue 3 简介
    • 1.2 响应式对象的重要性
    • 1.3 ref 和 reactive 的概述
  • 二、使用 ref
    • 2.1 ref 的创建方法
    • 2.2 ref 的使用方法
    • 2.3 ref 的适用场景
    • 2.4 ref 的局限性
  • 三、使用 reactive
    • 3.1 reactive 的创建方法
    • 3.2 reactive 的使用方法
    • 3.3 reactive 的适用场景
    • 3.4 reactive 的局限性
  • 四、对比 ref 和 reactive
    • 4.1 响应性方面的对比
    • 4.2 性能方面的对比
    • 4.3 使用场景的对比
    • 4.4 API 使用的对比
  • 五、总结

引言

Vue.js 是一个流行的 JavaScript 框架,它使得开发人员能够轻松地创建用户界面。在 Vue.js 中,响应式对象是非常重要的一部分,它们可以自动更新依赖它们的组件。在 Vue 3 中,有两种创建响应式对象的方法:使用 ref 和使用 reactive。这两种方法有一些区别,本文将详细介绍它们的区别以及使用方法。

一、介绍

1.1 Vue 3 简介

Vue 3 是 Vue.js 的最新版本,它带来了许多新的特性和改进,包括更好的性能、更简单的 API、更好的 TypeScript 支持等等。Vue 3 继续沿用了 Vue 2.x 的开发理念和模式,同时增加了一些新的概念和工具,使得开发者能够更高效地开发前端应用。

1.2 响应式对象的重要性

在 Vue.js 中,响应式对象是非常重要的一部分。当一个对象的属性被改变时,如果这个对象被用在 Vue 组件的模板中,那么这个组件会自动更新以反映新的属性值。这个特性使得开发者能够以声明式的方式构建用户界面,而不需要写很多的更新逻辑。

1.3 ref 和 reactive 的概述

在 Vue 3 中,有两种主要的方法来创建响应式对象:使用 ref 和使用 reactive。

ref 是 Vue 3 中用于创建响应式引用的函数。它返回一个包装过的对象,这个对象的值是可以改变的,但它的引用是不会改变的。这意味着你可以在模板中使用 ref,并且当它的值改变时,模板会自动更新。

reactive 是 Vue 3 中用于创建响应式对象的函数。它返回一个响应式对象,这个对象的属性和方法都可以改变。这意味着你可以在模板中使用 reactive,并且当它的属性或方法改变时,模板会自动更新。

二、使用 ref

2.1 ref 的创建方法

在 Vue 3 中,你可以使用 ref 函数来创建一个响应式引用。ref 函数可以接受一个初始值,并返回一个响应式对象。例如:

import { ref } from 'vue';  
  
const count = ref(0);

在这个例子中,我们创建了一个名为 count 的响应式引用,它的初始值为 0。

2.2 ref 的使用方法

使用 ref 的一个关键点是,你不能直接修改它的值。要修改 ref 的值,你需要使用 .value 属性。例如:

count.value++; // 修改 count 的值

你还可以通过 .get 方法来获取 ref 的当前值。例如:

console.log(count.get()); // 输出 0

2.3 ref 的适用场景

ref 最适合用于那些值需要改变,但引用不会改变的场景。例如,如果你有一个对象,而这个对象的某个属性是响应式的,那么你可以使用 ref 来创建这个属性。

2.4 ref 的局限性

ref 的一个局限性是,它只能用于原始数据类型(如字符串、数字、布尔值等),不能用于对象或数组。这意味着如果你需要创建一个包含多个属性的响应式对象,你需要使用 reactive 函数而不是 ref

三、使用 reactive

3.1 reactive 的创建方法

在 Vue 3 中,你可以使用 reactive 函数来创建一个响应式对象。reactive 函数可以接受一个初始对象作为参数,并返回一个响应式对象。例如:

import { reactive } from 'vue';  
  
const state = reactive({  
  count: 0,  
  name: 'John',  
});

在这个例子中,我们创建了一个名为 state 的响应式对象,它包含两个属性 countname

3.2 reactive 的使用方法

使用 reactive 的一个关键点是,你可以直接修改它的属性。例如:

state.count++; // 修改 state 的 count 属性  
state.name = 'Jane'; // 修改 state 的 name 属性

你还可以通过 reactive 函数创建一个响应式的方法或计算属性。例如:

const doubleCount = reactive({  
  get() {  
    return this.count * 2;  
  },  
});

在这个例子中,我们创建了一个名为 doubleCount 的响应式方法,它返回 count 的两倍。当你访问 doubleCount 时,它会动态地计算它的值。

3.3 reactive 的适用场景

reactive 函数最适合用于创建包含多个属性的响应式对象。由于 reactive 返回的是一个响应式对象,因此你可以直接修改它的属性,而不需要使用 .value 属性。

reactive 还可以用于创建包含方法或计算属性的响应式对象。你可以在响应式对象中定义方法或计算属性,并在模板中直接调用它们。这种方法在处理复杂的数据逻辑时非常有用。

reactive 也适用于那些需要同时跟踪多个状态的情况。通过使用 reactive,你可以将多个状态组织在一个响应式对象中,并在模板中方便地访问它们。

3.4 reactive 的局限性

虽然 reactive 提供了更广泛的响应式对象功能,但它确实有一些局限性。首先,与 ref 相比,reactive 的性能开销可能更大。因为 reactive 需要跟踪对象中的所有属性变化,而 ref 只需要跟踪一个原始值的变化。在性能敏感的应用程序中,使用 ref 可能是一个更好的选择。

其次,reactive 不支持 .set 方法。这意味着如果你想设置一个响应式对象的属性值,你只能直接赋值。这可能会引发一些不便。另外,如果你需要在响应式对象上添加一些额外的逻辑(例如 getter 或 setter),你可能需要使用 computed 或其他方法来实现,而不是直接在 reactive 中定义。

四、对比 ref 和 reactive

4.1 响应性方面的对比

refreactive 都可以创建响应式对象,但是在响应性方面,它们有一些区别。

使用 ref 创建的响应式引用只会响应原始值的改变。如果你将一个对象或者数组作为 ref 的初始值,那么当这个对象或数组中的某个元素发生改变时,ref 不会响应。只有当整个对象或数组被替换为新的对象或数组时,ref 才会响应。

相比之下,reactive 可以创建包含多个属性的响应式对象。当这些属性发生改变时,reactive 会立即响应并更新相关的组件。此外,reactive 还可以创建响应式的方法和计算属性,这是 ref 不支持的。

ref 更适合用于单个值的响应式引用,而 reactive 更适合用于包含多个属性或方法的响应式对象。

4.2 性能方面的对比

由于 ref 只关注单个原始值的改变,因此它的性能开销相对较小。相比之下,reactive 需要跟踪对象中的所有属性变化,因此它的性能开销可能更大。特别是在处理大量数据或复杂逻辑时,reactive 的性能开销可能会更加明显。

然而,需要注意的是,这种性能差异在很多情况下可能并不显著。对于大多数应用程序来说,refreactive 的性能差异不会对应用程序的整体性能产生太大影响。只有在处理非常大量的数据或进行高频率的更新时,这种性能差异才会变得明显。

因此,在选择使用 refreactive 时,需要根据具体的应用场景和需求进行权衡。如果需要处理大量数据或复杂逻辑,并且需要立即响应用户的输入或状态的改变,那么使用 reactive 可能更合适。如果只需要处理单个值的改变,并且对性能要求较高,那么使用 ref 可能更合适。

4.3 使用场景的对比

ref 更适合用于简单的数据引用,例如单个的数字、字符串或布尔值。当你需要响应这些简单数据的改变时,可以使用 ref。例如,如果你有一个表单,其中包含一些输入字段,你可以使用 ref 来存储和响应每个输入字段的值。

相比之下,reactive 更适合用于复杂的数据结构,例如对象或数组。当你需要同时处理多个属性的改变时,或者当你需要创建包含方法或计算属性的响应式对象时,可以使用 reactive。例如,如果你有一个购物车,其中包含多个商品,每个商品都有自己的数量和价格,你可以使用 reactive 来存储和响应整个购物车。

ref 更适合用于简单的数据引用,而 reactive 更适合用于复杂的数据结构。

4.4 API 使用的对比

ref 的 API 相对简单,只需要调用一次函数即可创建响应式引用。例如:

const count = ref(0);

reactive 需要调用两次函数,先创建一个普通的对象,然后再使用 reactive 包装它。例如:

const state = reactive({ count: 0 });

这意味着 reactive 的 API 使用可能更加繁琐一些。此外,reactive 还提供了更多的功能和选项,例如可以创建响应式的方法和计算属性。但是这也会增加学习的难度和复杂性。

ref 的 API 使用更加简单直接,而 reactive 的功能更加强大但学习难度也相对较大。选择使用哪个功能取决于具体的应用场景和个人需求。

五、总结

Vue 3 的 ref 和 reactive 是创建响应式对象的两种方法。ref 创建响应式引用,只能应用于单个原始值的情况。reactive 创建响应式对象,适用于包含多个属性或方法的复杂数据结构。ref 的 API 简单直接,而 reactive 提供了更多功能和选项。根据具体应用场景和个人需求选择使用哪种方法。

在这里插入图片描述

到这里我的分享就结束了,欢迎到评论区探讨交流!!
💖如果觉得有用的话还请点个赞吧 💖

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/108624.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Flink CDC 2.0 主要是借鉴 DBLog 算法

DBLog 算法原理 DBLog 这个算法的原理分成两个部分,第一部分是分 chunk,第二部分是读 chunk。分 chunk 就是把一张表分为多个 chunk(桶/片)。我可以把这些 chunk 分发给不同的并发的 task 去做。例如:有 reader1 和 re…

二叉树的最近公共祖先

题目: 样例: 输入 6 1 4 2 5 -1 -1 1 4 -1 -1 -1 -1 -1 3 输出 2 思路: 由题意,最近公共祖先就是,找出给出的两个结点的父结点 是谁。 这里有两种情况 1、给定的两个结点都是孩子结点 2、给定的两个结点&#xff…

【送书福利-第二十二期】《Vue.js 3企业级项目开发实战(微课视频版)》

😎 作者介绍:我是程序员洲洲,一个热爱写作的非著名程序员。CSDN全栈优质领域创作者、华为云博客社区云享专家、阿里云博客社区专家博主、前后端开发、人工智能研究生。公粽号:程序员洲洲。 🎈 本文专栏:本文…

Table-GPT:让大语言模型理解表格数据

llm对文本指令非常有用,但是如果我们尝试向模型提供某种文本格式的表格数据和该表格上的问题,LLM更有可能产生不准确的响应。 在这篇文章中,我们将介绍微软发表的一篇研究论文,“Table-GPT: Table- tuning GPT for Diverse Table…

用示例和应用程序了解必要的Golang库

Golang,也被称为Go,因其简单性、性能和并发性支持而在开发人员中迅速流行起来。导致Go成功的关键因素之一是其丰富的库生态系统,可以简化开发并提供解决常见问题的解决方案。在本文中,我们将更仔细地查看一些必要的Golang库&#…

心血管疾病药物不良反应不容忽视,华大基因基因检测辅助降低风险!

随着医疗技术的不断进步,个体化用药已经成为药物治疗的新趋势。在此趋势下,华大基因基因检测基于药物基因组学的药物选择和个性化用药方案,为心血管疾病患者的临床治疗提供了新机会,同时可以更好地帮助患者控制心血管疾病&#xf…

数据结构之栈的讲解(源代码+图解+习题)

我们在学习过顺序表和链表之后,了解了使用数组存储数据,使用结构体来存储数据和有关的指针,这些都是底层的东西,链表是靠指针的链接,顺序表是靠数组的下标才能得以实现增删查改。众多数据结构其实底层都离不开数组&…

HTML简单实现v-if与v-for与v-model

Vue启动!! 首先VIewModel将View和Model连接一起,Model的数据改变View的数据也变 使用Visual Studio Code 启动Vue需要vue.js插件和导入CDN(包) vue.js插件:CTRL shift x 在搜索栏搜 索vue.js安装即可 CDN: http…

使用Terraform管理已经存在的kubernates和默认的节点池

背景: 通过terraform resource "alicloud_cs_managed_kubernetes" "k8s" {...}创建集群时,会产生一个默认的节点池default-nodepool,但是如何去修改这个默认节点池的信息呢? 解决思路: 因为Ter…

2021美亚个人赛复现1

Individual_Container.zip.001下载以后显示是一个压缩包格式&#xff08;解压密码&#xff1a;MeiyaCup2021&#xff09; 解压得到Individual_Container加密容器&#xff0c;赛题存储在这里面 挂载密码HfsCk]<eUqc5Q{(DG$ugiGlt8ezGdaZ>!pQC-H\5BAc^gBo/^qq)/i21ufiNH&…

TELUS Ventures(泰勒斯)

TELUS Ventures&#xff08;泰勒斯&#xff09;高峰论坛于2023年10月28日在南京第5站正式开幕。该论坛是由泰勒斯风险投资公司主办的一项重要活动&#xff0c;旨在促进创新和创业精神的发展 。 这次高峰论坛将汇集来自全球各地的创业者、投资者和行业专家&#xff0c;共同探讨…

GO语言代码示例

首先&#xff0c;我们需要安装 rod 库&#xff0c;这是一个用于构建网络爬虫的 Go 语言库。 使用 go get 命令安装 rod 库&#xff1a;go get -u github.com/gofiber/rod 创建一个新的 Go 程序文件&#xff0c;例如&#xff1a;main.go 在 main.go 文件中&#xff0c;导入 r…

Go学习第十四章——Gin请求与响应

Go web框架——Gin请求与响应 1 响应1.1 String1.2 JSON&#xff08;*&#xff09;1.3 HTML&#xff08;*&#xff09;1.4 XML1.5 文件&#xff08;*&#xff09; 2 请求2.1 请求参数查询参数 (Query)动态参数 (Param)表单参数 (PostForm)原始参数 (GetRawData) 2.2 请求头2.3 …

在el-dialog中使用tinymce 点击工具栏下拉框被遮挡

在el-dialog中使用tinymce控件时&#xff0c;会出现点击工具栏下拉框出现在弹窗下一层&#xff0c;审查元素之后发现是tinymce的下拉框z-index优先级低于el-dialog的z-index导致的&#xff0c;所以需要增加tinymce的下拉框的z-index值。 通过审查元素得到&#xff0c;需要修改t…

【C语言】free()函数详解(动态内存释放函数)

&#x1f984;个人主页:修修修也 &#x1f38f;所属专栏:C语言 ⚙️操作环境:Visual Studio 2022 目录 一.free()函数简介 1.函数功能 2.函数参数 void * ptr 3.函数返回值 4.函数头文件 二.free()函数的具体使用 1.使用free()函数完成malloc()开辟空间的释放 2.使用fr…

Spring Cloud Alibaba Seata 实现 SAGA 事物

Seata 是一款开源的分布式事务解决方案&#xff0c;致力于提供高性能和简单易用的分布式事务服务。Seata 将为用户提供了 AT、TCC、SAGA 和 XA 事务模式&#xff0c;为用户打造一站式的分布式解决方案 Seata 官网&#xff1a;https://seata.io/zh-cn/ Spring Cloud Alibaba 官…

[Java/力扣100]判断两棵二叉树是否相同

我希望通过这道题&#xff0c;能进一步了解递归思想和“树是递归定义的”这句话 分析 我们的目的是写一个方法来检验两棵树是否相同 什么叫“两棵树相同”&#xff1f;——相同的位置存在相同的结点 有三种情况&#xff1a;1、两棵树一颗为空一颗不为空——不相同&#xff…

分类预测 | Matlab实现KOA-CNN-BiGRU-selfAttention多特征分类预测(自注意力机制)

分类预测 | Matlab实现KOA-CNN-BiGRU-selfAttention多特征分类预测&#xff08;自注意力机制&#xff09; 目录 分类预测 | Matlab实现KOA-CNN-BiGRU-selfAttention多特征分类预测&#xff08;自注意力机制&#xff09;分类效果基本描述程序设计参考资料 分类效果 基本描述 1.M…

oracle,CLOB转XML内存不足,ORA-27163: out of memory ORA-06512: at “SYS.XMLTYPE“,

通过kettle采集数据时&#xff0c;表输入的组件&#xff0c;查询报错。 ORA-27163: out of memory ORA-06512: at “SYS.XMLTYPE”, line 272 ORA-06512: at line 1 通过 ALTER SESSION SET EVENTS ‘31156 trace name context forever, level 0x400’; 修改会话配置 或直接修改…

工作组与域

目录 内网环境 内网环境分类 工作组 域 域的组成 域中的信任关系 父域与子域 域的结构 林中信任关系特点 域中的域名 活动目录&#xff08;AD&#xff09; 域中活动目录下的账号登录域中计算机过程 组织单位&#xff08;OU&#xff09; 组策略&#xff08;GPO&am…