vue3 - shallowReadonly浅层只读响应式对象

文章目录

    • [1. `shallowReadonly` 的作用](#1. shallowReadonly 的作用)
    • [2. 基本用法](#2. 基本用法)
    • [3. `shallowReadonly` 与 `readonly` 的区别](#3. shallowReadonlyreadonly 的区别)
    • [4. 使用场景](#4. 使用场景)
    • [5. 与 `readonly` 对比示例](#5. 与 readonly 对比示例)

Vue 3 中, shallowReadonly 是一个用于创建 浅层只读响应式对象 的 API,它与 readonly 类似,但有一个重要区别: 它只会让顶层属性只读,而不会递归地把嵌套对象也变成只读

下面我详细讲解 shallowReadonly 的作用、用法,以及与 readonly 的区别。

1. shallowReadonly 的作用

  • 将对象转换为 只读响应式对象
  • 只对顶层属性只读,嵌套对象仍然可以被修改。
  • 适合只需要保护顶层属性不被修改,而嵌套对象无需深度只读的场景。
  • readonly 相比,它不会对嵌套对象递归处理,从而减少性能开销。

2. 基本用法

js 复制代码
<template>
  <div>
    <h1>{{ state.count }}</h1>
    <h1>{{ state.nested.name }}</h1>
    <button @click="updateCount">修改顶层属性</button> <br />
    <button @click="updateShallowReadonly">强行修改嵌套属性</button>
  </div>
</template>
<script setup lang="ts">
import { shallowReadonly } from "vue";

const state = shallowReadonly({
  count: 0,
  nested: { name: "Vue" }
});

console.log(state.count); // 0
console.log(state.nested.name); // 'Vue'

// 定义一个方法来修改顶层属性
function updateCount() {
  state.count++; // 修改顶层属性,会触发警告(开发模式下)
  console.log("修改顶层属性:", state.count); // 警告:避免直接修改只读属性
}
// 定义一个方法来强行修改 shallowReadonly
function updateShallowReadonly() {
  // 修改嵌套对象的属性,不会触发视图更新
  state.nested.name = "React";
  console.log("强行修改嵌套属性后:", state.nested.name); // 输出 React
}
</script>
  • state.count 是顶层属性,Vue 会阻止修改。
  • state.nested.name 是嵌套属性,Vue 不会阻止修改,也不会触发警告,但视图不会更新。

如图所示:

3. shallowReadonlyreadonly 的区别

特性 readonly shallowReadonly
响应式深度 深度只读(递归处理嵌套对象) 浅层只读(只处理顶层属性)
修改嵌套对象行为 嵌套对象不可修改,会触发警告 嵌套对象可修改,不触发警告,视图也不会更新
性能开销 较大(递归代理整个对象) 较小(只代理顶层属性)
适用场景 需要完整深度保护对象,防止所有修改 只需保护顶层属性,优化性能

4. 使用场景

  1. 性能优化

    • 对大对象或深层嵌套对象,使用 shallowReadonly 可以避免递归代理,减少性能开销。
  2. 只保护顶层属性

    • 如果你只希望顶层属性保持只读,嵌套对象不必严格保护,使用 shallowReadonly 更合适。

5. 与 readonly 对比示例

javascript 复制代码
import { readonly, shallowReadonly } from "vue";

const deepObj1 = readonly({ nested: { value: 0 } });
const deepObj2 = shallowReadonly({ nested: { value: 0 } });

// 修改嵌套属性
deepObj1.nested.value = 1; // 会触发警告(深度只读)
deepObj2.nested.value = 1; // 不会触发警告(浅层只读)

// 修改顶层属性
deepObj1.nested = { value: 2 }; // 会触发警告
deepObj2.nested = { value: 2 }; // 会触发警告
  • readonly:无论是顶层属性还是嵌套属性,都不可修改。
  • shallowReadonly:只阻止顶层属性修改,嵌套属性可以修改。

👉点击进入 我的网站

相关推荐
等咸鱼的狸猫10 分钟前
JavaScript 隐式类型转换:从入门到精通
javascript
掘金一周31 分钟前
对车完全小白,不知买油买电还是买混动,求建议| 沸点周刊 7.2
前端·人工智能·后端
妙码生花1 小时前
从 PHP 到 AI + Golang,程序员自救转型手记(十六):目录结构更新、完善 token 系统(AI 表示 token 入库无需加密?)
前端·后端·ai编程
程序me1 小时前
Prompt、Context、Harness、Loop 之后是什么? AI工程下一个半年的关键词
前端·后端·ai编程
飞天狗1 小时前
线上Bug一直复现不了?我用Sentry把错误追踪效率提升了10倍
前端
Slice_cy1 小时前
对前端工程化的理解
前端
Slice_cy1 小时前
状态机设计理念与实现
前端
星栈1 小时前
LiveView 的生命周期:mount、handle_event 和 Socket 到底怎么运转
前端·前端框架·elixir
yingyima1 小时前
JWT Token 解析与安全实践速查:5 问 5 答直击要害
前端
kyriewen2 小时前
我用 Codex 重写了同事维护三年的代码,他没说谢谢——而是找了领导
前端·javascript·ai编程