Vue3 isProxy,isReactive,isReadonly 三者解析

1、isProxy

作用:判断当前数据是否为代理数据。

注意:它只对通过 reactive,readonly,shallowReactive,shallowReadonly 这四个方法包裹的数据返回true,对于 ref 以及通过 new Proxy 代理的数据返回都是false。

2、isReactive

作用:判断当前数据是否reactive包裹的数据。

注意:只对 reactive,shallowReactive 包裹的数据为true,其他为false。

3、isReadonly

作用:判断数据是否为readonly包裹的数据。

注意:只对 readonly,shallowReadonly 包裹的数据返回true,其他为false。

4、注意

如果 readonly 包裹的是一个 reactive 数据的话,那么 isReadonly, isReactive 都为true。

但是如果 reactive 包裹的是一个 readonly 的数据的话,那么 isReadonly 为true,isReactive 为false。

原因是:readonly 包裹的数据是一个只读的数据,不能在通过reactive方法进行代理。可以查看这两的数据。

readonlyObj

reactiveObj

可以看出 readonlyObj 被代理的2次,而 reactiveObj 被代理1次。所以 reactive(readonly(obj)) 这种只会被人 readonly 代理,不会再被 reactive 代理了。

相关推荐
计算机毕设VX:Fegn08951 小时前
计算机毕业设计|基于springboot + vue医院设备管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
明天好,会的1 小时前
分形生成实验(五):人机协同破局--30万token揭示Actix-web状态管理的微妙边界
运维·服务器·前端
C_心欲无痕1 小时前
nginx - alias 和 root 的区别详解
运维·前端·nginx
北辰alk1 小时前
Vue 路由信息获取全攻略:8 种方法深度解析
vue.js
北辰alk2 小时前
Vue 三剑客:组件、插件、插槽的深度辨析
vue.js
北辰alk2 小时前
Vue Watch 立即执行:5 种初始化调用方案全解析
vue.js
北辰alk2 小时前
Vue 组件模板的 7 种定义方式:从基础到高级的完整指南
vue.js
北辰alk2 小时前
深入理解 Vue 生命周期:created 与 mounted 的核心差异与实战指南
vue.js
计算机毕设VX:Fegn08952 小时前
计算机毕业设计|基于springboot + vue小型房屋租赁系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计