vue3当中ref有几种用法?什么情况下用,最合适,用reactive最好是什么时候,代码怎么写?

在Vue3中,ref有两种用法:基本用法和高级用法。

基本用法:

  1. 创建ref变量:使用ref函数,将普通数据类型转化为响应式对象。
js 复制代码
import { ref } from 'vue'

const count = ref(0) // 创建一个响应式对象count,初始值为0
  1. 获取ref变量的值:直接访问ref变量的value属性。
js 复制代码
console.log(count.value) // 输出0
  1. 修改ref变量的值:直接修改ref变量的value属性。
js 复制代码
count.value++ // 将count的值加一

高级用法:

  1. 创建ref对象:使用ref函数,传入一个对象,创建一个包含多个响应式变量的ref对象。
js 复制代码
import { ref } from 'vue'

const userInfo = ref({
  name: 'Tom',
  age: 18
})
  1. 获取ref对象的成员的值:访问ref对象的成员的value属性。
js 复制代码
console.log(userInfo.value.name) // 输出Tom
  1. 修改ref对象的成员的值:直接修改ref对象的成员的value属性。
js 复制代码
userInfo.value.age = 20 // 将userInfo的age属性修改为20

在什么情况下使用ref最合适?

  • 需要将普通数据类型转化为响应式对象时,可以使用ref。
  • 需要在template模板中使用数据时,需要使用ref。

使用reactive最好的时候:

  • 当需要创建一个包含多个响应式变量的对象时,可以使用reactive函数。

代码示例:

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

const state = reactive({
  count: 0,
  userInfo: {
    name: 'Tom',
    age: 18
  }
})

const countRef = ref(0)

console.log(state.count) // 输出0
console.log(state.userInfo.name) // 输出Tom
console.log(countRef.value) // 输出0

state.count++ // 将state的count属性加一
state.userInfo.age = 20 // 将state的userInfo的age属性修改为20
countRef.value++ // 将countRef的值加一
相关推荐
代码搬运媛几秒前
30分钟带你从0手搓一个AI-Cli命令行工具
前端
赛博切图仔7 分钟前
前端性能内卷终点?Signals 正在重塑我们的开发习惯
前端·javascript·vue.js
小江的记录本10 分钟前
【RAG】RAG检索增强生成(核心架构、全流程、RAG优化方案、常见问题与解决方案)
java·前端·人工智能·后端·python·机器学习·架构
程序员buddha13 分钟前
SCSS从0到1精通教程
前端·css·scss
ZC跨境爬虫20 分钟前
海南大学交友平台登录页开发实战day6(覆写接口+Flask 本地链接正常访问)
前端·后端·python·flask·html
Highcharts.js30 分钟前
抉择之巅:从2029年回望2026年——企业可视化“战略分水岭”?
前端·javascript·信息可视化·编辑器·echarts·highcharts
沙振宇31 分钟前
【Web】使用Vue3+PlayCanvas开发3D游戏(十)让人物动起来
前端·游戏·3d·人物·
米丘1 小时前
Vite 开发服务器启动时,如何将 client 注入 HTML?
javascript·node.js·vite
一 乐1 小时前
饮食营养信息|基于springboot + vue饮食营养管理信息平台系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·饮食营养管理信息系统
军军君011 小时前
数字孪生监控大屏实战模板:空气污染监控
前端·javascript·vue.js·typescript·前端框架·echarts·数字孪生