Vue3的reactive、ref、toRef、toRefs用法以及区别

在 Vue3 中,reactive, ref, toRef, toRefs 都是用于创建响应式数据的方法。它们之间的主要区别在于它们的使用方式和返回值类型。

  1. reactive:用于将一个普通对象转换为响应式对象。当对象的属性发生变化时,视图会自动更新。
javascript 复制代码
import { reactive } from 'vue';

const state = reactive({
  count: 0,
  info: {
    name: '张三',
    age: 18
  }
});
  1. ref:用于创建一个响应式的引用对象。它接受一个参数,可以是基本类型(如数字、字符串等),也可以是对象。当引用的值发生变化时,视图会自动更新。
javascript 复制代码
import { ref } from 'vue';

const count = ref(0);
const info = ref({
  name: '张三',
  age: 18
});
  1. toRef:用于创建一个响应式的引用对象,与 ref 类似,但它接受一个对象作为参数。当对象的属性发生变化时,视图会自动更新。
javascript 复制代码
import { toRef } from 'vue';

const state = reactive({
  info: {
    name: '张三',
    age: 18
  }
});

const nameRef = toRef(state, 'info.name');
const ageRef = toRef(state, 'info.age');
  1. toRefs:用于将一个响应式对象的所有属性转换为单独的响应式引用对象。这样可以让代码更易于理解和维护。
javascript 复制代码
import { reactive, toRefs } from 'vue';

const state = reactive({
  count: 0,
  info: {
    name: '张三',
    age: 18
  }
});

const { count, info } = toRefs(state);

总结:reactive 用于创建响应式对象,可以包含嵌套的对象;reftoRef 用于创建响应式的引用对象,只能包含基本类型或对象的某个属性;toRefs 用于将响应式对象的所有属性转换为单独的响应式引用对象。

相关推荐
一颗花生米。14 分钟前
深入理解JavaScript 的原型继承
java·开发语言·javascript·原型模式
学习使我快乐0118 分钟前
JS进阶 3——深入面向对象、原型
开发语言·前端·javascript
bobostudio199519 分钟前
TypeScript 设计模式之【策略模式】
前端·javascript·设计模式·typescript·策略模式
勿语&1 小时前
Element-UI Plus 暗黑主题切换及自定义主题色
开发语言·javascript·ui
黄尚圈圈1 小时前
Vue 中引入 ECharts 的详细步骤与示例
前端·vue.js·echarts
浮华似水2 小时前
简洁之道 - React Hook Form
前端
正小安4 小时前
如何在微信小程序中实现分包加载和预下载
前端·微信小程序·小程序
_.Switch6 小时前
Python Web 应用中的 API 网关集成与优化
开发语言·前端·后端·python·架构·log4j
一路向前的月光6 小时前
Vue2中的监听和计算属性的区别
前端·javascript·vue.js
长路 ㅤ   6 小时前
vite学习教程06、vite.config.js配置
前端·vite配置·端口设置·本地开发