vue3中reactive和ref如何使用和区别

在Vue3中,reactiveref都是响应式API。它们都可以用于创建响应式数据和观察其变化。

区别:

ref函数需要传入一个初始值,并返回一个对象,该对象有一个value属性,可以直接读取和赋值。而reactive函数可以传入一个普通对象,并生成一个响应式对象,该对象可以直接读取和修改属性。

示例:

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

// ref示例
const count = ref(0)
console.log(count.value) // 0
count.value++ // 直接对value属性进行赋值
console.log(count.value) // 1

// reactive示例
const state = reactive({
  count: 0,
  name: 'John'
})
console.log(state.count) // 0
state.count++ // 直接对属性进行赋值
console.log(state.count) // 1

ref函数适用于简单类型变量,比如数字、字符串等。而reactive函数适用于复杂类型变量,比如对象和数组。

示例:

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

// ref示例
const age = ref(18)
const name = ref('John')
console.log(age.value, name.value) // 18 John
age.value++ // 直接对value属性进行赋值
name.value = 'Mary'
console.log(age.value, name.value) // 19 Mary

// reactive示例
const state = reactive({
  name: 'John',
  info: {
    age: 18,
    sex: '男'
  }
})
console.log(state.info.age, state.info.sex) // 18 男
state.info.age++ // 直接对属性进行赋值
state.name = 'Mary'
console.log(state.info.age, state.name) // 19 Mary

综上所述,refreactive在使用上有所区别,适用于不同的场景。ref适用于简单类型变量,而reactive适用于复杂类型变量。

相关推荐
_AaronWong1 天前
Electron 实现仿豆包划词取词功能:从 AI 生成到落地踩坑记
前端·javascript·vue.js
cxxcode1 天前
I/O 多路复用:从浏览器到 Linux 内核
前端
用户5433081441941 天前
AI 时代,前端逆向的门槛已经低到离谱 — 以 Upwork 为例
前端
JarvanMo1 天前
Flutter 版本的 material_ui 已经上架 pub.dev 啦!快来抢先体验吧。
前端
JohnYan1 天前
工作笔记-CodeBuddy应用探索
javascript·ai编程·aiops
恋猫de小郭1 天前
AI 可以让 WIFI 实现监控室内人体位置和姿态,无需摄像头?
前端·人工智能·ai编程
哀木1 天前
给自己整一个 claude code,解锁编程新姿势
前端
程序员鱼皮1 天前
GitHub 关注突破 2w,我总结了 10 个涨星涨粉技巧!
前端·后端·github
UrbanJazzerati1 天前
Vue3 父子组件通信完全指南
前端·面试
是一碗螺丝粉1 天前
5分钟上手LangChain.js:用DeepSeek给你的App加上AI能力
前端·人工智能·langchain