Vue3响应式方法区别:ref、reactive、shallowRef和shallowReactive

Vue 3的响应性系统是其数据绑定的核心,它使得在响应式状态发生变化时,自动更新DOM成为可能。在本文中,我们将深入探讨Vue 3中四种重要的响应性方法:refreactiveshallowRefshallowReactive,并为你清晰解释它们的用途和区别。


一、ref():简单而强大

ref()是Vue 3中官方推荐的创建可变和响应式值的方式。它可用于处理原始值和非原始值,并支持深度响应性,即嵌套对象和数组内部的属性也是响应式的。这一方法使得在访问值时需要使用.value

示例:

xml 复制代码
<template>
  <h1>{{ student.age }}</h1>
  <button @click="addAge">点击我</button>
</template>
​
<script setup>
import { ref } from "vue";
​
const student = ref({
  name: "Tsz",
  age: 20
});
​
function addAge() {
  student.value.age += 10;
}
</script>

二、shallowRef():性能优化的选择

shallowRef()ref()类似,但它不支持深度响应性。只有通过.value访问时具有响应性,对状态的嵌套对象属性或数组元素的修改不会触发响应性。这一方法在需要优化性能并避免不必要的深度响应性跟踪时非常有用。

示例:

xml 复制代码
<template>
  <h1>{{ student.name }}</h1>
  <button @click="changeName">更改姓名</button>
</template>
​
<script setup>
import { shallowRef } from "vue";
​
const student = shallowRef({
  name: "Tsz",
  age: 20,
  comments: ["好文", "继续努力"]
});
​
function changeName() {
  student.value.name = "Alice";
  student.value.comments.push("我喜欢它");
}
</script>

三、reactive():对象的完全响应性

reactive()是用于在Vue 3中声明具有多个属性的对象的方法。使用reactive,整个对象变得响应式,包括对象内部的属性。这意味着对象内的属性会在更改时自动触发视图更新。

示例:

xml 复制代码
<template>
  <div>
    <h1>{{ student.name }}</h1>
    <p>年龄: {{ student.age }}</p>
    <button @click="updateStudent">更新学生信息</button>
  </div>
</template>
​
<script setup>
import { reactive } from "vue";
​
const student = reactive({
  name: "Tsz",
  age: 20
});
​
function updateStudent() {
  student.name = "Alice";
  student.age = 25;
}
</script>

四、shallowReactive():根属性的响应性

shallowReactive()reactive() 类似,但不同之处在于它只会使对象本身变得响应式,而不会深度追踪对象内部属性的变化。这意味着只有对象的属性被修改时才会触发响应,而对象内部嵌套的属性不会自动触发响应。

示例:

xml 复制代码
<template>
  <div>
    <h1>{{ student.name }}</h1>
    <p>年龄: {{ student.age }}</p>
    <button @click="updateStudent">更新学生信息</button>
  </div>
</template>
​
<script setup>
import { shallowReactive } from "vue";
​
const student = shallowReactive({
  name: "Tsz",
  age: 20,
  comments: ["好文", "继续努力"]
});
​
function updateStudent() {
  student.name = "Alice";
  student.age = 25;
  student.comments.push("我喜欢它");
}
</script>

在Vue 3中,根据你的具体需求,选择适当的方法可以帮助你提高开发效率并优化性能。希望本文对你理解Vue 3的响应性方法有所帮助。如果大家对这些方法有任何疑问可以留言讨论。

相关推荐
晚安7203 分钟前
Ajax相关
前端·javascript·ajax
图书馆钉子户5 分钟前
怎么使用ajax实现局部刷新
前端·ajax·okhttp
bin915321 分钟前
DeepSeek 助力 Vue 开发:打造丝滑的单选按钮(Radio Button)
前端·javascript·vue.js·ecmascript·deepseek
qianmoQ25 分钟前
第五章:工程化实践 - 第五节 - Tailwind CSS 常见问题解决方案
前端·css
那就可爱多一点点38 分钟前
超高清大图渲染性能优化实战:从页面卡死到流畅加载
前端·javascript·性能优化
不能只会打代码2 小时前
六十天前端强化训练之第一天HTML5语义化标签深度解析与博客搭建实战
前端·html·html5
OpenTiny社区2 小时前
Node.js技术原理分析系列——Node.js的perf_hooks模块作用和用法
前端·node.js
菲力蒲LY2 小时前
输入搜索、分组展示选项、下拉选取,全局跳转页,el-select 实现 —— 后端数据处理代码,抛砖引玉展思路
java·前端·mybatis
飞天大河豚3 小时前
2025前端框架最新组件解析与实战技巧:Vue与React的革新之路
vue.js·react.js·前端框架
MickeyCV3 小时前
Nginx学习笔记:常用命令&端口占用报错解决&Nginx核心配置文件解读
前端·nginx