Vue数据响应式reactive

基本作用

在Vue3中,reactive是用来创建响应式对象 ,reactive接收一个普通的对象,返回一个深层响应式代理对象,所谓"深层",是指对象的嵌套属性(包括数组,对象里的对象)也会被转成响应式的.

js 复制代码
import { reactive } from 'vue'
const state = reactive({
  count: 0,
  user: {
    name: '张三',
    age: 18
  }
})

现在,state.countstate.user.name的变化,都会被Vue追踪,并自动触发视图更新

与ref的区别

  • ref适合存储基本类型 (数字,字符串,布尔值),取值时需要.value
  • reactive更适合对象/数组 ,直接点属性即可,不需要.value
    示例对比:
js 复制代码
import { ref, reactive } from 'vue'

const num = ref(0)          // 基本类型
num.value++                 // 修改时要用 .value

const obj = reactive({ a: 1 })
obj.a++                     // 直接修改即可

特点

  1. 深层响应式
    不用担心嵌套对象不生效:
js 复制代码
   state.user.age++  // 会触发响应式更新
  1. 返回的是代理对象 :
    所以不能再用===直接对比原始对象和reactive对象
js 复制代码
const raw = { a: 1 }
const state = reactive(raw)
console.log(state === raw) // false
  1. 适合复杂状态管理
    在组件中维护多个字段,深层嵌套时,用reactive更直观

常见用法

  • 在setup里定义组件状态:
vue 复制代码
  <script setup>
import { reactive } from 'vue'

const state = reactive({
  count: 0,
  todos: []
})

function increment() {
  state.count++
}
</script>
<template>
  <div>
    <p>计数: {{ state.count }}</p>
    <button @click="increment">增加</button>
  </div>
</template>
  • 配合解构(注意要用toRefs否则响应式会丢失)
js 复制代码
import { reactive, toRefs } from 'vue'
const state = reactive({ count: 0, msg: 'hi' })
const { count, msg } = toRefs(state)
// 现在 count 和 msg 都是 ref

总结

  • reactive用于对象和数组的响应式转换
  • 配合ref一起用,可以灵活管理不同类型的状态
相关推荐
光影少年10 小时前
react性能优化比较好的办法有哪些?
前端·react.js·性能优化
fix一个write十个10 小时前
从零搭建音视频通话太痛苦?这个 Vue3 CallKit 让你 5 分钟搞定 1v1 + 群聊通话
前端·vue.js·github
竹林81810 小时前
用 wagmi v2 + WebSocket 硬磕 NFT 上架失败:一个前端开发者踩过的实时状态同步坑
javascript·next.js
豹哥学前端10 小时前
告别割裂式学习:待办清单项目,一次性掌握数组、本地存储与事件委托
前端·javascript
JYeontu10 小时前
照片墙太死板?做一个会随风摇摆的绳串图片交互效果
前端·javascript·css
2501_9159214310 小时前
HTTPS前端劫持 新一代流量劫持解决方案
前端·网络协议·ios·小程序·https·uni-app·iphone
Yue栎廷10 小时前
邪修:Markdown加粗语法**本土化改造
前端·javascript·人工智能
爱怪笑的小杰杰10 小时前
优化 UniApp 日历组件的多语言切换:告别 setLocale 引起的 App 重启
java·前端·uni-app
有所事事10 小时前
如何让AI写代码越写越像你
前端·后端
Allen正心正念202510 小时前
前端——Node.js&npm,学点前端的东西
前端·npm·node.js