玩转Vue3之shallowRef和shallowReactive

前言

Vue3 作为一款现代的 JavaScript 框架,引入了许多新的特性和改进,其中包括 shallowRefshallowReactive。这两个功能在Vue 3中提供了更加灵活和高效的状态管理选项,尤其适用于大型和复杂的应用程序。

Vue 3 的响应式系统

Vue3 引入了新的响应式系统,与 Vue2相比,它具有更好的性能和更多的功能。这个新系统基于 Proxy,为开发者提供了更直观、灵活的API,其中包括ref、reactive、shallowRef和shallowReactive等。之前的文章写过有关响应式系统的解释,在本博客中,我们将深入探讨这两个API,并提供一些具体的例子,以便更好地理解它们的用法和优势。

1.shallowRef:浅层响应式引用

shallowRef 是一个创建响应式对象的函数,与 ref 不同之处在于,shallowRef 只会在对象的第一层进行响应式处理。这意味着当对象的深层属性发生变化时,不会触发视图更新,从而提高了性能。

让我们看一个例子:

js 复制代码
import { shallowRef, watchEffect } from 'vue';

const user = shallowRef({
  name: 'John',
  address: {
    city: 'New York',
    zip: '10001'
  }
});

watchEffect(() => {
  console.log('User changed:', user.value);
});

// 修改深层属性,不会触发视图更新
user.value.address.city = 'San Francisco';

在上面的例子中,watchEffect 只会在 name 属性发生变化时触发,而不会在 address 的变化时触发。这有助于避免不必要的性能开销,这对于一些场景非常有用,例如在处理大型数据集合时,可以提高性能并减少不必要的更新。

2.shallowReactive:浅层响应式对象

shallowRef 类似,shallowReactive 用于创建一个浅层响应式的对象。这意味着只有对象的第一层属性会被响应化,这对于避免在深层次对象中进行递归响应式转换非常有用。

js 复制代码
import { shallowReactive, watchEffect } from 'vue';

const user = shallowReactive({
  name: 'John',
  address: {
    city: 'New York',
    zip: '10001'
  }
});

watchEffect(() => {
  console.log('User changed:', user);
});

// 修改深层属性,不会触发视图更新
user.address.city = 'San Francisco';

在上述例子中,watchEffect 只在 name 属性变化时触发,而 address 属性的变化不会引起更新。

使用场景

1. 性能优化

在处理大型数据集或嵌套对象时,使用 shallowRefshallowReactive 可以提高性能,避免不必要的响应式转换和更新。

2. 避免无限循环

当你在数据模型中存在相互引用的情况时,使用 shallowRefshallowReactive 可以帮助你避免创建无限循环的响应式数据。

3. 更精确的控制

如果你只关心对象的第一层属性,而不希望触发深层次的更新,那么 shallowRefshallowReactive 提供了更精确的控制。

结论

使用 shallowRefshallowReactive 的性能优势在于避免了深层对象的递归侦听,从而减少了触发响应式系统的次数。这对于大型项目和数据结构来说是非常有用的。

通过了解它们的使用方式和性能优势,我们可以更好地利用 Vue3 的响应式系统。始终记住,在使用这些特性时,要根据具体情况权衡性能和开发的便利性,确保你的代码保持清晰、易读和可维护。

相关推荐
唯之为之10 小时前
# Vue3.5常用特性整理
vue3·ssr
于指尖飞舞16 小时前
在vue3中使用datav完整引入时卡在加载页面的解决方法
vue3·报错·datav
猫猫村晨总1 天前
基于 Vue3 + Canvas + Web Worker 实现高性能图像黑白转换工具的设计与实现
前端·vue3·canvas
上官熊猫2 天前
nuxt3项目打包部署到服务器后配置端口号和开启https
前端·vue3·nuxt3
璇璇吴2 天前
vue3 el-form表格滚动
javascript·vue3·elementplus
放逐者-保持本心,方可放逐9 天前
vue2 升级为 vue3+第三方库升级+vue2与vue3混合交互
vue3·vue2·交互·项目升级·第三方库升级
花铛12 天前
《Vue3 八》<script setup> 语法
vue3
想要打 Acm 的小周同学呀13 天前
若依框架--数据字典设计使用和前后端代码分析
java·vue3·数据字典·若依
飞雪金灵14 天前
Vue3(elementPlus) el-table替换/隐藏行箭头,点击整行展开
前端·vue3·element-plus·隐藏table箭头·替换table展开箭头·点击整行展开
xiangxiongfly91516 天前
Vue3 自定义插件(plugin)
vue3·插件·plugin