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

相关推荐
wuxia21187 分钟前
微信小程序单击元素切换元素的显示和隐藏
javascript·微信小程序·setdata
JustHappy14 分钟前
古法编程秘籍(二):什么是代码模块化?别背概念,把房间收拾明白就够了
前端·后端
小江的记录本21 分钟前
【JVM虚拟机】堆内存分代模型:年轻代(Eden+Survivor)、老年代、元空间Metaspace(附《思维导图》+《面试高频考点清单》)
java·前端·jvm·后端·python·spring·面试
weixin_4713830344 分钟前
图片预解码缓存
前端·浏览器缓存·图片预解码
一起学开源1 小时前
一文读懂 ReAct 范式:让 AI Agent 真正学会“思考+行动“
java·javascript·react.js·ecmascript·react·alibaba·智能体开发
岁月宁静2 小时前
驾驭 AI 这匹野马:深入解析智能体 Harness 工程
vue.js·python
郑洁文2 小时前
基于网络爬虫的Web敏感信息泄露自动化检测工具
前端·爬虫·网络安全·自动化
游九尘2 小时前
JavaScript 实现三段式版本号对比函数(app升级用)
javascript·uni-app
zhiSiBuYu05173 小时前
Claude-Code 新手极速上手指南
javascript·node.js
郑洁文3 小时前
可视化Web渗透分析工具的设计与实现
前端