reactive和ref的异同、toRef和toRefs的使用

news/2024/4/27 19:12:25/文章来源:https://blog.csdn.net/Niucode/article/details/136970916

一、reactive和ref

有了reactive为什么还要ref?

ref处理起基本数据类型来更加的方便快捷,性能要更好。

ref 内部值的变化只会触发订阅它的副作用函数(effect)更新,而 reactive(Proxy) 内部对象的任何属性变化都会触发整个对象的重新渲染。

相同点:

  1. 都是 Vue 3 提供的用于创建响应式数据的函数;
  2. 在组件中都能够触发视图更新,实现数据的双向绑定。

不同点:

  1. 数据类型

    • reactive:主要用于处理对象或数组等复杂数据类型,将整个对象转为响应式对象;
    • ref:主要用于处理基本类型数据(如数字、字符串等)或单一值,将单一值转为响应式数据。
  2. 使用方式

    • reactive:接收一个普通对象作为参数,并返回一个包含响应式数据的代理对象。

      import { reactive } from 'vue';const state = reactive({count: 0
      });
      
    • ref:接收一个初始值作为参数,并返回一个包含响应式数据的引用对象。

      import { ref } from 'vue';const count = ref(0);
      
  3. 访问方式

    • reactive:直接通过对象属性访问。

      state.count++;
      
    • ref:需要通过 .value 属性来访问或修改值。

      count.value++;
      
  4. 特殊情况

    • ref 对象是通过 .value 来访问内部值的;而 reactive 返回的代理对象可以直接访问属性值。
    • 当需要监听一个基本类型的值时,通常会使用 ref;当需要监听一个对象或数组的多个属性时,使用 reactive 更方便。

ref里面放对象或者数组也是合法的,但可能会出现以下问题,所以最好还是用reactive。

  1. 内部值访问:由于 ref 对象内部的值是通过 .value 属性来访问的,因此如果你这样创建了一个 ref 对象:const myRef = ref({val: 1}),那么在访问该对象的值时需要通过 myRef.value.val 来获取属性值,这会使代码显得冗长和不够直观。

  2. 响应性ref 主要用于处理基本类型数据或单一值,而不是复杂对象。当使用 ref({val: 1}) 创建一个 ref 对象时,其内部的对象可能不会被完全响应化,即对象内部属性的变化可能不会触发视图更新。

  3. 深度监听:Vue 的响应式系统不会对对象进行深度监听,即对象内部嵌套的对象或数组的变化不会被自动追踪。因此,如果 ref 内部的对象包含深层次的属性,可能会导致部分属性的变化无法被及时监听到。

二、toRef / toRefs

作用
toRef 和 toRefs 可以用来复制 reactive 里面的属性然后转成 ref,而且它既保留了响应式,也保留了引用,也就是你从 reactive 复制过来的属性进行修改后,除了视图会更新,原有 ractive 里面对应的值也会跟着更新,浅拷贝,它复制的其实就是引用 + 响应式 ref。(这样的转换可以提高数据响应式的性能,使数据的访问和操作更加方便和直观)

不加 s 和 加 s 的区别就是这样:

toRef: 复制 reactive 里的单个属性并转成 ref;
toRefs: 复制 reactive 里的所有属性并转成 ref。

使用方式 

toRef

<template><h2>reactive-greet: {{ info.greet }} </h2><h2>toRef-greet: {{ rGreet }}</h2><button @click="onChangeGreet">更换问候语</button>
</template><script>
import { reactive, toRef } from 'vue'
export default {setup() {let info = reactive({name: 'Tony',greet: 'Hello'})// 复制 info 里的 greet 属性let rGreet = toRef(info, 'greet')// 更改 rGreetconst onChangeGreet = () => {rGreet.value = 'world!'}return {info,rGreet,onChangeGreet}}
}
</script>

 更改 rRgeet 的同时更改了原有的 info.greet 属性

 toRefs

<template><h2>reactive-info-greet: {{ info.greet }} </h2>// 要带上 .value<h2>toRefs-rInfo-greet: {{ rInfo.greet.value }}</h2><button @click="onChangeGreet">更新</button>
</template><script>
import { reactive, toRefs } from 'vue'
export default {setup() {let info = reactive({name: 'Tony',greet: 'Hello'})// 复制整个 infolet rInfo = toRefs(info)// 更改 rInfo.greetconst onChangeGreet = () => {rInfo.greet.value = 'world!'}return {info,rInfo,onChangeGreet}}
}
</script>

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

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

相关文章

Linux 系统基础操作命令

当前市面上常见的系统&#xff1a;Windows、Linux、Mac OS、Android、IOS…… Linux 不太适合日常使用&#xff0c;但是非常适合用于开发。因此作为一个程序猿来说&#xff0c;Linux 都是务必要掌握的。 Linux 介绍 Linux 发行版 目前市面上比较知名的发行版有&#xff1a;R…

DNS隧道攻击

什么是DNS隧道&#xff1f; DNS隧道是一种网络通信技术&#xff0c;它利用DNS&#xff08;Domain Name System&#xff0c;域名系统&#xff09;协议来建立隐蔽的通信通道。在正常情况下&#xff0c;DNS协议主要用于将域名解析为IP地址&#xff0c;但攻击者可以通过构造特殊的…

总结 | vue3项目初始化(附相应链接)

如何运行 vue 项目&#xff1a;vscode运行vue项目_vscode启动vue项目命令-CSDN博客 vue3项目搭建 目录管理 git管理&#xff1a;vue3项目搭建并git管理_git 新建vue3项目-CSDN博客 目录调整&#xff1a;vue3项目 - 目录调整-CSDN博客 vscode中快速生成vue3模板&#xff1a…

实现能效升级 | 基于ACM32 MCU的冰箱压缩机变频方案

概述 冰箱制冷系统中最重要的部件是压缩机。它从吸气管吸入低温低压的制冷剂气体&#xff0c;通过电机运转带动活塞对其进行压缩后&#xff0c;向排气管排出高温高压的制冷剂气体&#xff0c;为整个制冷循环提供源动力。这样就实现了压缩→冷凝→膨胀→蒸发 ( 吸热 ) 的制冷循环…

并查集|1971. 寻找图中是否存在路径、684.冗余连接、685.冗余连接II

目录 并查集基础 1971. 寻找图中是否存在路径 684.冗余连接 685.冗余连接II 并查集基础 并查集主要有三个功能。 寻找根节点&#xff0c;函数&#xff1a;find(int u)&#xff0c;也就是判断这个节点的祖先节点是哪个将两个节点接入到同一个集合&#xff0c;函数&#xf…

项目中自动引入神器 - unplugin-auto-import/unplugin-vue-components

前端 项目中 自动引入 神器 前言 在开发中&#xff0c;我们总喜欢站在巨人的肩膀上开发&#xff0c;比如用一些 框架&#xff1a;vue,react, 组件库&#xff1a;element&#xff0c;ant。 工具函数&#xff1a;axios&#xff0c;lodash 现在是模块化时代&#xff0c;我们…

新手入门C语言之联合体和枚举

在上一篇文章中&#xff0c;我们了解到在C语言中&#xff0c;自定义类型有三种&#xff0c;这里我们介绍后两种&#xff0c;联合体和枚举。 一.联合体 1.联合体的声明 像结构体一样&#xff0c;联合体也是由一个或多个成员构成&#xff0c;这些成员的类型可以是不一样的&…

Go——结构体

Go语言中没有类的概念&#xff0c;也不支持类的继承等面向对象的概念。Go语言中通过结构体的内嵌再配合接口比面向对象具有更高的扩展性和灵活性。 一. 类型别名和自定义类型 1.1 自定义类型 在Go语言中有一些基本的数据类型&#xff0c;如string&#xff0c;整型&#xff0c;…

手机网页关键词视频爬虫采集软件可导出视频分享链接|视频无水印批量下载工具

全新音视频批量下载工具&#xff0c;为您解放视频管理烦恼&#xff01; 现如今&#xff0c;音上涌现出大量精彩的视频内容&#xff0c;但是要想高效地获取、管理和分享这些视频却是一件颇具挑战的事情。针对这一难题&#xff0c;我们自主研发了全新的音视频批量下载工具&#x…

数学建模体育建模和经济建模国防科大版

目录 6.体育中的数学建模 7.经济学问题中的数学建模 7.1.实物交换模型 7.2.边际效应 7.3.最佳消费选择模型 6.体育中的数学建模 体育科学的研究中&#xff0c;也有大量的数学建模问题&#xff0c;例如&#xff1a;棒球的最佳击球点问题、滑板滑雪赛道的设计、越野自行车比…

各种需要使用的方法-->vue/微信小程序/layui

各种需要使用的方法-->vue/微信小程序/layui 1、vue里样式不起作用的方法&#xff0c;可以通过deep穿透的方式2、 js获取本周、上周、本月、上月日期3、ArrayBuffer Blob 格式转换ArrayBuffer与Blob的区别ArrayBuffer转BlobBlob转ArrayBuffer需要借助fileReader对象 4、使用…

STM32使用滴答定时器实现delayms

在STM32上使用SysTick实现jiffies&#xff08;时间戳&#xff09;并且实现delay_ms 代码实现&#xff1a; volatile uint32_t jiffies 0; // 用于记录系统运行的jiffies数 void SysTick_Handler(void) {/* 每次SysTick中断&#xff0c;jiffies增加 */jiffies; }uint32_t tick…

如何利用生成式人工智能挑选合适的候选人?

在当今激烈的商业竞争中&#xff0c;招聘合适的人才是构建企业成功的基石。筛选和面试候选人是一个复杂且精细的过程&#xff0c;它不仅关系到职位的有效填补&#xff0c;更影响到企业的长期发展和团队建设。 选择合适候选人的重要性 选择合适的候选人就像寻找一片沙滩上的珍…

曲线生成 | 图解Reeds-Shepp曲线生成原理(附ROS C++/Python/Matlab仿真)

目录 0 专栏介绍1 什么是Reeds-Shepp曲线&#xff1f;2 Reeds-Shepp曲线的运动模式3 Reeds-Shepp曲线算法原理3.1 坐标变换3.2 时间翻转(time-flip)3.3 反射变换(reflect)3.4 后向变换(backwards) 4 仿真实现4.1 ROS C实现4.2 Python实现4.3 Matlab实现 0 专栏介绍 &#x1f5…

MP4如何把视频转MOV格式? MP4视频转MOV格式的技巧

在现代的数字媒体时代&#xff0c;视频格式转换成为了许多用户必须掌握的技能。特别是将MP4视频转换为MOV格式&#xff0c;这对于需要在Apple设备上播放或编辑视频的用户来说尤为重要。本文将详细介绍如何将MP4视频转换为MOV格式&#xff0c;帮助读者轻松应对不同设备和平台的需…

编程语言|C语言——C语言基本数据类型

前言 针对不同的数据&#xff0c;采取不同的存储方式和进行不同的处理。随着处理对象的复杂化&#xff0c;数据类型也要变得更丰富。数据类型的丰富程度直接反映了程序设计语言处理数据的能力。 C语言很重要的一个特点是它的数据类型十分丰富。因此&#xff0c;C语言程序数据处…

【Nuxt3】modules目录和nuxt3模块的简单介绍

简言 记录下nuxt3项目中module的用法 modules目录 使用 modules/ 目录在应用程序中自动注册本地模块。 这是一个很好的地方&#xff0c;可以放置您在构建应用程序时开发的任何本地nuxt模块。 nuxt模块相当于npm包&#xff0c;可以发布到npm社区中 在modules/ 目录下的本地模…

二叉树|654.最大二叉树

力扣题目地址 class Solution { public:TreeNode* constructMaximumBinaryTree(vector<int>& nums) {TreeNode* node new TreeNode(0);if (nums.size() 1) {node->val nums[0];return node;}// 找到数组中最大的值和对应的下标int maxValue 0;int maxValueIn…

Kubernetes生产集群部署指南

部署生产就绪的Kubernetes集群需要考虑到管理、负载均衡、安全、存储等很多细节&#xff0c;本文给出了一个生产就绪Kubernetes集群的完整部署流程&#xff0c;可以作为生产部署的有效参考。原文: Deploying a Production Kubernetes Cluster in 2023 — A Complete Guide Grow…

万兆车载以太网转换器 10G/2.5G多速车载以太网转换器-MC10GM

MC10GM转换器 一、产品简要分析 2.5G,5G,10G可切换万兆/多速车载以太网转换器。采用罗森博格H-MTD标准接口类型。实现将车载以太网标准2.5/5/10G BASE-T1转换为工业级2.5/5/10G 标准以太网&#xff0c;进而接入电脑或工控机. 产品实现2.5/5/10G Base-T1 和2.5/5/10G Base-R之间…