Vue3 学习 6

其他API

【shallowRef与shallowReactive】

shallowRef

1.作用:创建一个响应式数据,但只对顶层属性进行响应式处理

2.用法:

复制代码
	let myVar = shallowRef(initialValue);

3.特点:只跟踪引用值的变化,不关心值内部的属性变化
shallowReactive

1.作用:创建浅响应式对象,只会使对象的最顶层属性变成响应式的,对象内部的嵌套属性则不会变成响应式的

2.用法:

复制代码
	const myObj = shallowReactive({...})

3.特点:对象的顶层属性是响应式的,但嵌套对象的属性不是

【readonly与shallowReadonly】

readonly

1.作用:用于创建一个对象的深只读副本

2.用法:

复制代码
	const original = reactive({....})
	const readOnlyCopy = readonly(oringal);

3.特点:

  • 对象的所有嵌套属性都将变为只读
  • 任何尝试修改这个对象的操作都会被阻止
    4.应用场景:
  • 创建不可变的状态快照
  • 保护全局状态或配置不可修改

** shallowReadonly**

1.作用:与readonly类似,但只作用于对象的顶层属性

2.用法:

复制代码
	const original = reactive({...});
	const shallowReadOnlyCopy = shallowReadonly(original);

【toRaw与markRaw】

toRaw

1.作用:用于获取一个响应式对象的原始对象,toRaw返回的对象不再是响应式的,不会触发试图更新

在需要响应式对象传递给非Vue的库或外部系统时,使用toRaw可以确保他们收到的是普通对象

markRaw

1.作用:标记一个对象,使其永远都不会变为响应式的

例如使用mockjs时,为了防止误把mockjs变为响应式对象,可以使用markRaw去标记mockjs

【customRef】

作用:创建一个自定义的ref,并对其依赖项跟踪和更新触发进行逻辑控制

相关推荐
donecoding1 小时前
一个 sudo 引发的血案:npm 全局包权限错乱彻底修复
前端·node.js·前端工程化
我命由我123451 小时前
Kotlin 开发 - lateinit 关键字
android·java·开发语言·kotlin·android studio·android-studio·android runtime
风骏时光牛马1 小时前
Raku正则匹配与数据批量处理实操案例
前端
Halo_tjn1 小时前
Java Set集合相关知识点
java·开发语言·算法
nbwenren1 小时前
2026实测:Gemini 3 镜像站视觉能力实践——拍照原型图,一键生成 HTML+CSS 代码
前端·css·html
Lee川1 小时前
Prisma 实战指南:像搭积木一样设计古诗词数据库
前端·数据库·后端
许彰午1 小时前
我手写了一个 Java 内存数据库(二):B+ 树的插入与分裂
java·开发语言·面试
sakiko_1 小时前
UIKit学习笔记5-使用UITableView制作聊天页面
笔记·学习·swift·uikit
jinanwuhuaguo1 小时前
(第二十九篇)OpenClaw 实时与具身的跃迁——从异步孤岛到数字世界的“原住民”
前端·网络·人工智能·重构·openclaw