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

相关推荐
天天打码几秒前
Bootstrap Table开源的企业级数据表格集成
前端·开源·bootstrap
Allen Bright3 分钟前
【CSS-8】深入理解CSS选择器权重:掌握样式优先级的关键
前端·css
hnlucky5 分钟前
安装vue的教程——Windows Node.js Vue项目搭建
前端·javascript·vue.js·windows·node.js
余道各努力,千里自同风18 分钟前
CSS“多列布局”
前端·css·html
苏_Berlvy20 分钟前
javascript中Cookie、BOM、DOM的使用
javascript
Keya24 分钟前
使用 tinypng 脚本打包为exe 进行压缩图片
前端·python·程序员
wordbaby30 分钟前
React Router 的 handle 和 useMatches 的作用、场景和联系
前端·react.js
我的div丢了肿么办30 分钟前
ResizeObserver和IntersectionObserver的详细讲解
前端·javascript·vue.js
凌览31 分钟前
斩获 7k Star,这个桌宠项目火了🔥
前端·javascript·后端
opbr32 分钟前
🔥 扔掉虚拟DOM!百行代码实现高性能Vue内核,直接操作DOM竟这么香?
前端