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:只阻止顶层属性修改,嵌套属性可以修改。

👉点击进入 我的网站

相关推荐
华玥作者1 天前
[特殊字符] VitePress 对接 Algolia AI 问答(DocSearch + AI Search)完整实战(下)
前端·人工智能·ai
Mr Xu_1 天前
告别冗长 switch-case:Vue 项目中基于映射表的优雅路由数据匹配方案
前端·javascript·vue.js
前端摸鱼匠1 天前
Vue 3 的toRefs保持响应性:讲解toRefs在解构响应式对象时的作用
前端·javascript·vue.js·前端框架·ecmascript
sleeppingfrog1 天前
zebra通过zpl语言实现中文打印(二)
javascript
lang201509281 天前
JSR-340 :高性能Web开发新标准
java·前端·servlet
好家伙VCC1 天前
### WebRTC技术:实时通信的革新与实现####webRTC(Web Real-TimeComm
java·前端·python·webrtc
未来之窗软件服务1 天前
未来之窗昭和仙君(六十五)Vue与跨地区多部门开发—东方仙盟练气
前端·javascript·vue.js·仙盟创梦ide·东方仙盟·昭和仙君
baidu_247438611 天前
Android ViewModel定时任务
android·开发语言·javascript
嘿起屁儿整1 天前
面试点(网络层面)
前端·网络
VT.馒头1 天前
【力扣】2721. 并行执行异步函数
前端·javascript·算法·leetcode·typescript