Vue3.如何把一个对象内的键值变成响应式变量

在 Vue 3 中,若要把 tables 对象里的内容作为变量声明并使用,可借助 reactive 或者 toRefs 来达成。下面为你详细介绍这两种方式:

方法一:使用 reactive

reactive 用于创建响应式对象,你可以把 tables 对象包装成响应式对象,然后在模板或者 setup 函数里使用这些属性。

html 复制代码
<template>
  <div>
    <p>{{ tables.a }}</p>
    <p>{{ tables.b }}</p>
  </div>
</template>

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

const tables = { a: '', b: '' };
// 将 tables 对象转换为响应式对象
const reactiveTables = reactive(tables);

// 在 setup 函数中使用这些属性
console.log(reactiveTables.a);
console.log(reactiveTables.b);
</script>

代码解释

  • 运用 reactive 函数把 tables 对象转换为响应式对象 reactiveTables。
  • 在模板里通过 {{ reactiveTables.a }} 和 {{ reactiveTables.b }} 来访问这些属性。
  • 在 setup 函数里也能直接使用 reactiveTables.a 和 reactiveTables.b。

方法二:使用 toRefs

toRefs 用于将响应式对象的属性转换为响应式引用,这样就能在解构赋值后依然保持响应式。

代码解释

  • 先使用 reactive 函数把 tables 对象转换为响应式对象 reactiveTables。
  • 接着使用 toRefs 函数将 reactiveTables 对象的属性转换为响应式引用。
  • 通过解构赋值将 a 和 b 提取出来,在模板里可以直接使用 {{ a }} 和 {{ b }} 访问这些属性。
  • 在 setup 函数里,需要通过 .value 来访问这些属性的值。

这两种方法都能让你在 Vue 3 里使用 tables 对象的属性,你可以依据具体需求选择合适的方法

相关推荐
donecoding5 小时前
一个 sudo 引发的血案:npm 全局包权限错乱彻底修复
前端·node.js·前端工程化
风骏时光牛马5 小时前
Raku正则匹配与数据批量处理实操案例
前端
nbwenren5 小时前
2026实测:Gemini 3 镜像站视觉能力实践——拍照原型图,一键生成 HTML+CSS 代码
前端·css·html
Lee川5 小时前
Prisma 实战指南:像搭积木一样设计古诗词数据库
前端·数据库·后端
Linsk5 小时前
Java和JavaScript的关系真是雷峰和雷峰塔的关系吗?
java·javascript·oracle
当时只道寻常5 小时前
浏览器文本复制到剪贴板:企业级最佳实践
javascript
jinanwuhuaguo5 小时前
(第二十九篇)OpenClaw 实时与具身的跃迁——从异步孤岛到数字世界的“原住民”
前端·网络·人工智能·重构·openclaw
广州华水科技5 小时前
深度测评2026年单北斗GNSS位移监测系统推荐,与高口碑变形监测设备一同引领行业新风尚
前端
Alice-YUE6 小时前
【js高频八股】防抖与节流
开发语言·前端·javascript·笔记·学习·ecmascript