`shallowReactive` 与 `shallowRef`:浅层响应式 API

🤍 前端开发工程师、技术日更博主、已过CET6

🍨 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1

🕠 牛客 高级专题作者、打造专栏《前端面试必备》《2024面试高频手撕题》《前端求职突破计划》

🍚 蓝桥云课 签约作者、上架课程《Vue.js 和 Egg.js 开发企业级健康管理项目》《带你从入门到实战全面掌握 uni-app》

文章目录

在 Vue3 中,shallowReactiveshallowRef 是两种特殊的响应式 API,它们提供了一种浅层响应式的方式来处理对象和引用类型的数据。

shallowReactive

shallowReactive 创建一个浅层响应式对象。这意味着只有对象的顶层属性是响应式的,嵌套的对象属性不会被转换为响应式。

使用 shallowReactive

javascript 复制代码
import { shallowReactive } from 'vue';

const state = shallowReactive({
foo: 1,
bar: {
baz: 2
}
});

// 改变顶层属性会触发更新
state.foo++; // 响应式

// 改变嵌套属性不会触发更新
state.bar.baz++; // 非响应式

shallowRef

shallowRef 创建一个浅层响应式的引用。与普通的 ref 不同,shallowRef 只有在引用的值本身改变时才会触发更新,如果引用的对象内部的属性发生变化,不会触发更新。

使用 shallowRef

javascript 复制代码
import { shallowRef } from 'vue';

const state = shallowRef({
foo: 1,
bar: {
baz: 2
}
});

// 改变引用的值会触发更新
state.value = { foo: 2 }; // 响应式

// 改变引用对象的属性不会触发更新
state.value.bar.baz++; // 非响应式

适用场景

shallowReactiveshallowRef 适用于以下场景:

  • 当你有一个大型数据结构,并且只想对顶层属性进行响应式处理时。
  • 当你知道嵌套对象不会改变,或者你不关心嵌套对象内部的变化时。
  • 当你需要优化性能,并且可以接受一定程度的非响应式行为时。

总结

  • shallowReactiveshallowRef 提供了浅层响应式的行为,只有顶层属性或引用本身的改变才会触发更新。
  • 这两种 API 在处理大型数据结构或优化性能时非常有用。
  • 使用它们时需要注意,嵌套对象的内部变化不会触发视图更新。
相关推荐
kyriewen9 小时前
我手写了一个 EventEmitter,面试官追问了 6 个问题——第 4 个我没答上来
前端·javascript·面试
IT_陈寒10 小时前
Java的Date类又坑了我一次,改用时间戳真香
前端·人工智能·后端
山河木马10 小时前
矩阵专题2-怎么创建视图矩阵(uViewMatrix)
javascript·webgl·计算机图形学
小林攻城狮10 小时前
使用 Transport 节流解决 Vercel AI SDK 流式渲染卡死问题
前端·react.js
前端缘梦10 小时前
告别 TS 运行时类型漏洞!Zod 完整入门实战教程(前端 / 全栈必备)
前端·react.js·全栈
the_answer11 小时前
Webpack vs Vite 深度对比分析
前端·webpack
转转技术团队11 小时前
验证码识别实战:前端不写页面,改训模型了?
前端
MomentYY11 小时前
Temperature:AI 的“脑洞旋钮”
前端·llm·ai编程
远航_11 小时前
OpenSpec 完整详细介绍
前端·后端
召钱熏11 小时前
状态枚举正确≠渲染正确:一个语音按钮的状态机边界修复实录
android·前端