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的值加一
相关推荐
2401_859049083 分钟前
git submodule update --init --recursive无法拉取解决
前端·chrome·git
这是个栗子21 分钟前
【Vue代码分析】前端动态路由传参与可选参数标记:实现“添加/查看”模式的灵活路由配置
前端·javascript·vue.js
刘一说30 分钟前
Vue 动态路由参数丢失问题详解:为什么 `:id` 拿不到值?
前端·javascript·vue.js
熊猫钓鱼>_>1 小时前
动态网站发布部署核心问题详解
前端·nginx·容器化·网页开发·云服务器·静态部署
方也_arkling1 小时前
elementPlus按需导入配置
前端·javascript·vue.js
爱吃大芒果1 小时前
Flutter for OpenHarmony 实战: mango_shop 资源文件管理与鸿蒙适配
javascript·flutter·harmonyos
我的xiaodoujiao1 小时前
使用 Python 语言 从 0 到 1 搭建完整 Web UI自动化测试学习系列 44--将自动化测试结果自动推送至钉钉工作群聊
前端·python·测试工具·ui·pytest
沛沛老爹1 小时前
Web开发者转型AI:多模态Agent视频分析技能开发实战
前端·人工智能·音视频
David凉宸1 小时前
vue2与vue3的差异在哪里?
前端·javascript·vue.js
Irene19911 小时前
JavaScript字符串转数字方法总结
javascript·隐式转换