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,并对其依赖项跟踪和更新触发进行逻辑控制

相关推荐
麦麦鸡腿堡15 小时前
JavaWeb_请求参数,设置响应数据,分层解耦
java·开发语言·前端
2301_8194143015 小时前
C++与区块链智能合约
开发语言·c++·算法
不想看见40415 小时前
Valid Parentheses栈和队列--力扣101算法题解笔记
开发语言·数据结构·c++
炸膛坦客16 小时前
单片机/C/C++八股:(十五)内存对齐、结构体内存对齐
c语言·开发语言·单片机
娇娇yyyyyy16 小时前
QT编程(13): Qt 事件机制eventfilter
开发语言·qt
bcbobo21cn16 小时前
C# byte类型和byte数组的使用
开发语言·c#·字节数组·byte类型
计算机安禾16 小时前
【C语言程序设计】第37篇:链表数据结构(一):单向链表的实现
c语言·开发语言·数据结构·c++·算法·链表·蓝桥杯
阿贵---16 小时前
C++构建缓存加速
开发语言·c++·算法
Dxy123931021616 小时前
CSS常用样式详解:从基础到进阶的全面指南
前端·css
IT_陈寒16 小时前
SpringBoot自动配置揭秘:5个让开发效率翻倍的隐藏技巧
前端·人工智能·后端