百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术分类 > 正文

vue3中到底使用Ref还是Reactive,我和同事吵起来了

ztj100 2025-04-30 21:22 28 浏览 0 评论

事情是这样的,我和同事在vue3中到底是使用ref还是reactive起了争执。

我觉得应该更好的使用ref,Ref 既能声明基本数据类型,也能声明对象和数组,而且不容易失去响应式,reactive操作不当容易失去响应式。

而同事认为开发表单或多个值的时候都会优先采用reactive,数据集中,结构明了。

所以结果就是我准备写这篇文章来记录一下这两者的区别和用法。

ref和Reactive的区别

  1. 数据类型
  • ref主要用于基本数据类型(如字符串、数字、布尔值等)以及引用数据类型(对象)。使用ref定义的数据可以通过.value属性访问和修改。
  • reactive主要用于将对象转换为响应式数据,包括复杂的嵌套对象和数组。使用reactive定义的数据可以直接访问和修改属性。
  1. 访问方式
  • ref通过.value属性访问和修改值。
  • reactive直接访问和修改对象的属性,不需要使用.value
  1. 响应性追踪
  • ref追踪单个独立的引用,即只有当.value属性被访问或修改时才会触发依赖追踪。
  • reactive追踪整个对象及其内部属性,当任何属性被修改时,所有依赖于这些属性的视图都会自动更新。
  1. 可变性
  • ref的引用值可以重新赋值,而不会影响其响应性。
  • reactive对象本身是不可重新赋值的,只能修改其内部属性。如果直接重新赋值整个对象,会导致响应性丢失。

ref的使用注意事项

  1. 必要性ref应该只在必要时使用,因为它可能会影响性能。
  2. 内存泄漏:确保在组件销毁时解除对ref的引用,以避免内存泄漏。
  3. 值的可变性ref的值是可变的,所以要小心地使用它,避免意外地修改其值。

reactive的使用注意事项

  1. 重新赋值问题:对于reactive对象,不能直接重新赋值整个对象,否则会失去响应性。应通过修改对象的属性来保持响应性。
  2. 解构赋值问题:解构赋值会导致响应性丢失,因为解构后的新变量不是响应式的。可以使用toRefs函数将响应式对象转换为包含多个ref的对象,以确保每个属性保持响应性。

应用场景和示例代码

ref的应用场景

  1. 简单数据管理:需要管理单一的基本数据类型,如计数器、开关状态等。
 import { ref } from 'vue';

const count = ref(0);
function increment() {
count.value++;
}
  1. 模板中解构响应式对象:在组合式API中,如果将响应式对象解构到模板中,ref可以保持解构后的响应性。
 import { ref, toRefs } from 'vue';

const state = ref({ count: 0, name: 'Vue' });
const count = toRefs(state).count;
const name = toRefs(state).name;
  1. 引用DOM元素:在模板中引用DOM元素时,可以使用ref进行挂载。
<template>
<input ref="inputElement" />
<button @click="focusInput">Focus Input</button>
</template>

<script setup>
import { ref } from 'vue';

const inputElement = ref(null);
const focusInput = () => {
inputElement.value.focus();
};
</script>

reactive的应用场景

  1. 复杂对象和嵌套数据:当需要管理包含多个属性和嵌套结构的对象时,reactive更加适合。
import { reactive } from 'vue';

const user = reactive({
name: 'John',
age: 30,
address: {
city: 'New York',
country: 'USA'
}
});
  1. 性能考虑:在某些情况下,使用reactive可能会在性能上更优,因为它避免了频繁的.value访问。

创作不易,如果这篇文章对你有用,欢迎点赞关注加评论哦

小伙伴们在工作中还遇到过其他应用场景吗,欢迎评论区留言讨论哦。

相关推荐

30天学会Python编程:16. Python常用标准库使用教程

16.1collections模块16.1.1高级数据结构16.1.2示例...

强烈推荐!Python 这个宝藏库 re 正则匹配

Python的re模块(RegularExpression正则表达式)提供各种正则表达式的匹配操作。...

Python爬虫中正则表达式的用法,只讲如何应用,不讲原理

Python爬虫:正则的用法(非原理)。大家好,这节课给大家讲正则的实际用法,不讲原理,通俗易懂的讲如何用正则抓取内容。·导入re库,这里是需要从html这段字符串中提取出中间的那几个文字。实例一个对...

Python数据分析实战-正则提取文本的URL网址和邮箱(源码和效果)

实现功能:Python数据分析实战-利用正则表达式提取文本中的URL网址和邮箱...

python爬虫教程之爬取当当网 Top 500 本五星好评书籍

我们使用requests和re来写一个爬虫作为一个爱看书的你(说的跟真的似的)怎么能发现好书呢?所以我们爬取当当网的前500本好五星评书籍怎么样?ok接下来就是学习python的正确姿...

深入理解re模块:Python中的正则表达式神器解析

在Python中,"re"是一个强大的模块,用于处理正则表达式(regularexpressions)。正则表达式是一种强大的文本模式匹配工具,用于在字符串中查找、替换或提取特定模式...

如何使用正则表达式和 Python 匹配不以模式开头的字符串

需要在Python中使用正则表达式来匹配不以给定模式开头的字符串吗?如果是这样,你可以使用下面的语法来查找所有的字符串,除了那些不以https开始的字符串。r"^(?!https).*&...

先Mark后用!8分钟读懂 Python 性能优化

从本文总结了Python开发时,遇到的性能优化问题的定位和解决。概述:性能优化的原则——优化需要优化的部分。性能优化的一般步骤:首先,让你的程序跑起来结果一切正常。然后,运行这个结果正常的代码,看看它...

Python“三步”即可爬取,毋庸置疑

声明:本实例仅供学习,切忌遵守robots协议,请不要使用多线程等方式频繁访问网站。#第一步导入模块importreimportrequests#第二步获取你想爬取的网页地址,发送请求,获取网页内...

简单学Python——re库(正则表达式)2(split、findall、和sub)

1、split():分割字符串,返回列表语法:re.split('分隔符','目标字符串')例如:importrere.split(',','...

Lavazza拉瓦萨再度牵手上海大师赛

阅读此文前,麻烦您点击一下“关注”,方便您进行讨论和分享。Lavazza拉瓦萨再度牵手上海大师赛标题:2024上海大师赛:网球与咖啡的浪漫邂逅在2024年的上海劳力士大师赛上,拉瓦萨咖啡再次成为官...

ArkUI-X构建Android平台AAR及使用

本教程主要讲述如何利用ArkUI-XSDK完成AndroidAAR开发,实现基于ArkTS的声明式开发范式在android平台显示。包括:1.跨平台Library工程开发介绍...

Deepseek写歌详细教程(怎样用deepseek写歌功能)

以下为结合DeepSeek及相关工具实现AI写歌的详细教程,涵盖作词、作曲、演唱全流程:一、核心流程三步法1.AI生成歌词-打开DeepSeek(网页/APP/API),使用结构化提示词生成歌词:...

“AI说唱解说影视”走红,“零基础入行”靠谱吗?本报记者实测

“手里翻找冻鱼,精心的布局;老漠却不言语,脸上带笑意……”《狂飙》剧情被写成歌词,再配上“科目三”背景音乐的演唱,这段1分钟30秒的视频受到了无数网友的点赞。最近一段时间随着AI技术的发展,说唱解说影...

AI音乐制作神器揭秘!3款工具让你秒变高手

在音乐创作的领域里,每个人都有一颗想要成为大师的心。但是面对复杂的乐理知识和繁复的制作过程,许多人的热情被一点点消磨。...

取消回复欢迎 发表评论: