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 代理了。

相关推荐
张风捷特烈5 小时前
状态管理大乱斗#03 | Provider 源码全面评析
android·前端·flutter
灵感__idea11 小时前
Hello 算法:“走一步看一步”的智慧
前端·javascript·算法
吴文周12 小时前
告别重复劳动:一套插件让 AI 替你写代码、修Bug、做测试、上生产
前端·后端·ai编程
Mh13 小时前
我决定写一个 3D 地球仪来记录下我要去的地方
前端·javascript·动效
yaoxin52112313 小时前
390. Java IO API - WatchDir 示例
java·前端·python
懒狗小前端13 小时前
做了一个 codex 的中文文档网站,做的不好可以随便喷
前端·后端
. . . . .14 小时前
ref、useRef 和 forwardRef
前端·javascript·react.js
energy_DT15 小时前
2026年海上钻井平台数字孪生平台:引领海洋能源数字化转型
前端
Eric_见嘉15 小时前
在职前端 Agent 配置分享
前端·后端·agent
柚子81615 小时前
break跳出语句块的神奇技巧
前端·javascript