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

相关推荐
易营宝3 分钟前
全球建站SaaS平台能提升SEO评分吗?是否值得切换?
大数据·前端·人工智能
C_心欲无痕5 分钟前
Next.js 的服务端路由:对应api文件夹
开发语言·javascript·ecmascript
513495925 分钟前
在Vue.js项目中使用docx和file-saver实现Word文档导出
前端·vue.js·word
zh_xuan16 分钟前
kotlin 类委托
开发语言·kotlin
虾说羊20 分钟前
Langchain4j中AIService学习
学习
墨雨晨曦8832 分钟前
2026/01/20 java总结
java·开发语言
代码游侠37 分钟前
嵌入式开发——ARM Cortex-A7内核和i.MX6处理器相关的底层头文件
arm开发·笔记·嵌入式硬件·学习·架构
look ahead to41 分钟前
关于PYQT qt designer的网格布局 单控件占多行的处理
开发语言·qt·pyqt
王德博客41 分钟前
【C++继承】笔试易错题目
开发语言·c++·继承
卖个几把萌44 分钟前
解决 Python 项目依赖冲突:使用 pip-tools 一键生成现代化的 requirements.txt
开发语言·python·pip