Vue3中ref和reactive的区别及说明

 更新时间:2024年11月06日 09:06:59   作者:合格的程序员  
在Vue3中,ref主要用于基本数据类型和单个数据管理,需要用.value访问,reactive适用于对象和多数据管理,直接访问属性,ref支持解构保持响应性,reactive解构后失去响应性,选择合适的方法可以使代码更优化

Vue3 ref和reactive的区别

在 Vue 3 中,refreactive 都是用来创建响应式数据的方法

但它们有以下主要区别:

1. 使用场景不同

ref:

  • 主要用于基本数据类型(String、Number、Boolean 等)
  • 也可以用于对象/数组,但需要通过 .value 访问
  • 适合单个响应式数据的管理
import { ref } from 'vue'

// 基本类型
const count = ref(0)
console.log(count.value) // 0

// 对象类型
const user = ref({
  name: 'Tom',
  age: 18
})
console.log(user.value.name) // 'Tom'

reactive:

  • 主要用于对象类型(Object、Array)
  • 直接访问属性,不需要 .value
  • 适合多个响应式数据的管理
import { reactive } from 'vue'

const state = reactive({
  name: 'Tom',
  age: 18,
  hobbies: ['reading', 'swimming']
})
console.log(state.name) // 'Tom'

2. 访问方式不同

ref:

  • 在 setup 中需要通过 .value 访问
  • 在模板中自动解包,直接使用
<script setup>
import { ref } from 'vue'

const count = ref(0)
// setup 中需要 .value
const increment = () => {
  count.value++
}
</script>

<template>
  <!-- 模板中直接使用,不需要 .value -->
  <div>{{ count }}</div>
</template>

reactive:

  • 直接访问属性,不需要 .value
  • 在模板和 setup 中的访问方式相同
<script setup>
import { reactive } from 'vue'

const state = reactive({
  count: 0
})
// 直接访问
const increment = () => {
  state.count++
}
</script>

<template>
  <!-- 直接访问 -->
  <div>{{ state.count }}</div>
</template>

3. 解构行为不同

ref:

  • 支持解构,解构后仍然保持响应性
  • 可以使用 toRefs 将 reactive 对象的属性转换为 ref
import { ref, toRefs } from 'vue'

const user = reactive({
  name: ref('Tom'),
  age: ref(18)
})

// ref 解构后保持响应性
const { name, age } = toRefs(user)
name.value = 'Jerry' // 仍然是响应式的

reactive:

  • 解构后会失去响应性
  • 需要使用 toRefs 保持响应性
import { reactive } from 'vue'

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

// 直接解构会失去响应性
const { name, age } = state
name = 'Jerry' // 不再是响应式的

// 使用 toRefs 保持响应性
const { name, age } = toRefs(state)
name.value = 'Jerry' // 仍然是响应式的

4. 使用建议

  1. 使用 ref 的场景:
    • 基本数据类型的响应式
    • 需要解构的响应式数据
    • 单个响应式数据的管理
const count = ref(0)
const message = ref('hello')
const isVisible = ref(true)
  1. 使用 reactive 的场景:
    • 复杂对象的响应式
    • 多个相关数据的组合
    • 不需要解构的数据管理
const state = reactive({
  user: {
    name: 'Tom',
    age: 18
  },
  settings: {
    theme: 'dark',
    notifications: true
  }
})
  1. 混合使用:
    • 可以在 reactive 对象中使用 ref
    • 使用 toRefs 转换 reactive 对象为 ref
const state = reactive({
  count: ref(0),
  user: {
    name: ref('Tom'),
    age: ref(18)
  }
})

// 转换为 ref
const { count, user } = toRefs(state)

通过理解这些区别,你可以根据具体场景选择合适的响应式方案,使代码更加清晰和易于维护。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • vscode+vue cli3.0创建项目配置Prettier+eslint方式

    vscode+vue cli3.0创建项目配置Prettier+eslint方式

    这篇文章主要介绍了vscode+vue cli3.0创建项目配置Prettier+eslint方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-10-10
  • 使用Vue3和p5.js实现交互式图像动画

    使用Vue3和p5.js实现交互式图像动画

    这篇文章主要介绍了如何用Vue3和p5.js打造一个交互式图像动画,文中给出了详细的代码示例,本代码适用于需要在网页中实现图像滑动效果的场景,例如图片浏览、相册展示等,感兴趣的小伙伴跟着小编一起来看看吧
    2024-06-06
  • vue实现局部刷新的实现示例

    vue实现局部刷新的实现示例

    这篇文章主要介绍了vue实现局部刷新的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-04-04
  • vue 递归组件的简单使用示例

    vue 递归组件的简单使用示例

    这篇文章主要介绍了vue 递归组件的简单使用示例,帮助大家更好的理解和使用vue框架,感兴趣的朋友可以了解下
    2021-01-01
  • vue computed无法得到this的属性或方法的解决

    vue computed无法得到this的属性或方法的解决

    这篇文章主要介绍了vue computed无法得到this的属性或方法的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-07-07
  • vue3路由新玩法useRoute和useRouter详解

    vue3路由新玩法useRoute和useRouter详解

    这篇文章主要介绍了vue3路由新玩法useRoute和useRouter,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-08-08
  • vue3-HTTP请求方式

    vue3-HTTP请求方式

    这篇文章主要介绍了vue3-HTTP请求方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-06-06
  • vue3 + element-plus 的 upload + axios + django 实现文件上传并保存功能

    vue3 + element-plus 的 upload + axios + django 实现文件上

    这篇文章主要介绍了vue3 + element-plus 的 upload + axios + django 文件上传并保存,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2024-01-01
  • 从零开始封装自己的自定义Vue组件

    从零开始封装自己的自定义Vue组件

    如何封装自己的Vue组件,如何把自己的Vue代码封装成公共组件,今天为大家简单介绍一下如何封装自己的Vue组件
    2018-10-10
  • 在pycharm中开发vue的方法步骤

    在pycharm中开发vue的方法步骤

    这篇文章主要介绍了在pycharm中开发vue的方法步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-03-03

最新评论