Vue中的 ref、toRef 和 toRefs

ref

ref 是创建一个响应式的引用对象。这个对象有一个 .value 属性,用来存储任何类型的值(包括基本类型和复杂类型)。当这个值改变时,依赖于它的模板或计算属性会自动更新。

javascript 复制代码
import { ref } from 'vue';

const count = ref(0); // 创建一个值为 0 的响应式引用
console.log(count.value); // 访问值
count.value++; // 修改值

toRef

toRef 是将一个对象的属性转换成一个 ref,这样即使原始对象的属性发生变化,新的 ref 也会保持响应性。

javascript 复制代码
import { toRef } from 'vue';

const state = { count: 0 };
const count = toRef(state, 'count'); // 将 state.count 转换为一个 ref

state.count = 1; // 改变原对象的属性
console.log(count.value); // 输出 1,说明 count 仍然是响应式的

toRefs

toRefs 是将一个包含多个响应式属性的对象转换成一个普通对象,其中每个属性都是一个 ref。这通常用于将响应式对象解构为单独的 ref,以避免失去响应性。

javascript 复制代码
import { reactive, toRefs } from 'vue';

const state = reactive({ count: 0, name: 'Vue' });
const stateAsRefs = toRefs(state); // 将 state 的所有属性转换为 ref

state.count = 1; // 改变原对象的属性
console.log(stateAsRefs.count.value); // 输出 1
console.log(stateAsRefs.name.value); // 输出 'Vue'

主要区别

ref 是用于创建一个新的响应式引用,可以是任何类型的数据。

toRef 是用于将现有对象的一个特定属性转换为 ref,它不会创建新的数据副本,而是与原对象的属性保持同步。

toRefs 是用于将整个响应式对象的所有属性都转换为 ref,常用于函数组件中接收 props 或者解构响应式对象时,确保解构后的变量仍然具有响应性。

相关推荐
Moment7 分钟前
MinIO已死,MinIO万岁
前端·后端·github
无双_Joney11 分钟前
心路散文 - 转职遇到AI浪潮,AIGC时刻人的价值是什么?
前端·后端·架构
有意义31 分钟前
深度拆解分割等和子集:一维DP数组与倒序遍历的本质
前端·算法·面试
卤蛋fg635 分钟前
vxe-table 如何实现分组列头折叠列功能
vue.js
小怪点点38 分钟前
vue3使用
前端·vue.js
Bigger1 小时前
CSS 这些年都经历了什么?一次看懂 CSS 的演化史
前端·css·前端工程化
DevUI团队1 小时前
🚀 【Angular】MateChat V20.2.2版本发布,新增8+组件,欢迎体验~
前端·javascript·人工智能
嚴寒1 小时前
前端配环境配到崩溃?这个一键脚手架让我少掉了一把头发
前端·react.js·架构
DevUI团队2 小时前
🚀 MateChat V1.11.0 震撼发布!新增工具按钮栏组件及体验问题修复,欢迎体验~
前端·javascript·人工智能
学以智用2 小时前
Vue 3 核心函数全解(组合式 API + 常用工具函数)
javascript·vue.js