vue3如何判断是不是响应式数据

· isRef: 检查一个值是否为一个 ref 对象

· isReactive: 检查一个对象是否是由 reactive 创建的响应式代理

· isReadonly: 检查一个对象是否是由 readonly 创建的只读代理

· isProxy: 检查一个对象是否是由 reactive 或者 readonly 方法创建的代理

<template><div></div>
</template><script lang="ts">
import {defineComponent,ref,reactive,customRef,readonly,shallowReadonly,shallowReactive,shallowRef,toRefs,toRaw,markRaw,isRef,isReactive,isReadonly,isProxy,
} from 'vue'
// vue3.0 版本语法
export default defineComponent({setup () {/*响应式数据的判断isRef: 检查一个值是否为一个 ref 对象isReactive: 检查一个对象是否是由 reactive 创建的响应式代理isReadonly: 检查一个对象是否是由 readonly 创建的只读代理isProxy: 检查一个对象是否是由 reactive 或者 readonly 方法创建的代理*/const refObj = ref('')logFun(refObj,'refObj')const reactiveObj = reactive({})logFun(reactiveObj,'reactiveObj')const readonlyObj = readonly({})logFun(readonlyObj,'readonlyObj')const shallowReadonlyObj = shallowReadonly({})logFun(shallowReadonlyObj,'shallowReadonlyObj')const toRefsObj1 = reactive({toRefsObj: {}})const { toRefsObj } =  toRefs(toRefsObj1)logFun(toRefsObj,'toRefsObj')const shallowReactiveObj =  shallowReactive({})logFun(shallowReactiveObj,'shallowReactiveObj')const shallowRefObj =  shallowRef({})logFun(shallowRefObj,'shallowRefObj')// customRef自定义一个Reffunction myCustomRef(value) {return customRef((track, trigger) => {return {get() {track() // 追踪后续数据的变化return value},set(newValue) {value = newValuetrigger() // 重新解析模板}}})}let customRefObj = myCustomRef('hello')logFun(customRefObj,'customRefObj')const toRawObjRef = toRaw(refObj)logFun(toRawObjRef,'toRawObjRef')const markRawObjRef = markRaw(refObj)logFun(markRawObjRef,'markRawObjRef')const toRawObjReactive = toRaw(reactiveObj)logFun(toRawObjReactive,'toRawObjReactive')const markRawObjReactive = markRaw(reactiveObj)logFun(markRawObjReactive,'markRawObjReactive')// 统一调用判断函数function logFun (obj,type) {console.log(type+':','isRef(obj)',isRef(obj),'/isReactive(obj)',isReactive(obj),'/isReadonly(obj)',isReadonly(obj),'isProxy(obj)',isProxy(obj));}return {//}},
})
</script>

页面显示结果:

显示结果拷贝了一份,看看这4种判断方式的对于各种类型的对象判断结果:

refObj:

isRef(obj) true /isReactive(obj) false /isReadonly(obj) false isProxy(obj) false

reactiveObj:

isRef(obj) false /isReactive(obj) true /isReadonly(obj) false isProxy(obj) true

readonlyObj:

isRef(obj) false /isReactive(obj) false /isReadonly(obj) true isProxy(obj) true

shallowReadonlyObj:

isRef(obj) false /isReactive(obj) false /isReadonly(obj) true isProxy(obj) true

toRefsObj:

isRef(obj) true /isReactive(obj) false /isReadonly(obj) false isProxy(obj) false

shallowReactiveObj:

isRef(obj) false /isReactive(obj) true /isReadonly(obj) false isProxy(obj) true

shallowRefObj:

isRef(obj) true /isReactive(obj) false /isReadonly(obj) false isProxy(obj) false

customRefObj:

isRef(obj) true /isReactive(obj) false /isReadonly(obj) false isProxy(obj) false

toRawObjRef:

isRef(obj) true /isReactive(obj) false /isReadonly(obj) false isProxy(obj) false

markRawObjRef:

isRef(obj) true /isReactive(obj) false /isReadonly(obj) false isProxy(obj) false

toRawObjReactive:

isRef(obj) false /isReactive(obj) false /isReadonly(obj) false isProxy(obj) false

markRawObjReactive:

isRef(obj) false /isReactive(obj) true /isReadonly(obj) false isProxy(obj) true

欢迎关注我的原创文章:小伙伴们!我是一名热衷于前端开发的作者,致力于分享我的知识和经验,帮助其他学习前端的小伙伴们。在我的文章中,你将会找到大量关于前端开发的精彩内容。

学习前端技术是现代互联网时代中非常重要的一项技能。无论你是想成为一名专业的前端工程师,还是仅仅对前端开发感兴趣,我的文章将能为你提供宝贵的指导和知识。

在我的文章中,你将会学到如何使用HTML、CSS和JavaScript创建精美的网页。我将深入讲解每个语言的基础知识,并提供一些实用技巧和最佳实践。无论你是初学者还是有一定经验的开发者,我的文章都能够满足你的学习需求。

此外,我还会分享一些关于前端开发的最新动态和行业趋势。互联网技术在不断发展,新的框架和工具层出不穷。通过我的文章,你将会了解到最新的前端技术趋势,并了解如何应对这些变化。

我深知学习前端不易,因此我将尽力以简洁明了的方式解释复杂的概念,并提供一些易于理解的实例和案例。我希望我的文章能够帮助你更快地理解前端开发,并提升你的技能。

如果你想了解更多关于前端开发的内容,不妨关注我的原创文章。我会不定期更新,为你带来最新的前端技术和知识。感谢你的关注和支持,我们一起探讨交流技术共同进步,期待与你一同探索前端开发的奇妙世界!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/178469.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

allure修改logo 自定义

无论pytest还是httprunner都适用allure生成报告。那我们就有必要对allure报告进行一些定制。我们先修改logo&#xff1a; 1、给allure.yml插件custom-logo-plugin 找到allure安装的位置&#xff0c;在config文件夹下有一个allure.yml的配置文件。打开它&#xff0c;在最后添加…

Python接口自动化测试 ---Allure报告使用详解

这一节主要是记录allure的内容以及用法&#xff0c;怎么让他生成一个完整的想要的报告。 allure生成的报告和其他五花八门的报告对比了一下&#xff0c;它的可读性是最好、最直观的。这不仅仅是我想要的效果&#xff0c;也是很多小伙伴想要的结果&#xff0c;毕竟这是给领导看…

扩散模型DDPM学习笔记

扩散模型DDPM 文章目录 扩散模型DDPM如何运作基本概念训练过程推理过程&#xff1a; 目标损失函数推导评估标准 论文地址&#xff1a; Denoising Diffusion Probabilistic Models (DDPM) 如何运作 ​ 从guassian distribution进行采样得到一个噪声的图片&#xff0c;图片大小…

【复杂网络建模】——ER网络度分布、无标度网络度分布

目录 一、复杂网络介绍 二、ER网络、SF网络介绍 1、ER网络(Erdős-Rnyi网络)

测开笔记--Typescript: 文件复制到指定目录

开发背景&#xff1a; 自动化开发语言使用的是TypeScript&#xff1b;框架用的是playwright。有个测试脚本需要先将几个文件复制粘贴到新建的项目文件夹下&#xff0c;系统会读取该文件&#xff0c;然后生成页面信息。 关键字&#xff1a;文件复制粘贴&#xff1b; 新建的项目…

为什么我不能给shopify的图片添加alt

首先我们要明白是什么ALT标签&#xff0c;为什么要添加这个标签&#xff0c;这个标签有什么用 ALT标签是什么 ALT属性是HTML的一部分&#xff0c;它为那些无法查看图像的用户提供替代的文本描述。 ALT标签有什么用 使用ALT属性还可以帮助搜索引擎爬虫更好地理解您的网站内容。有…

SpringBoot配置多个不同Thymeleaf模板位置

最近开发当中需要在SpringBoot配置多个不同Thymeleaf位置&#xff0c;特此记录下相关过程 默认Thymeleaf配置 当我们集成thymeleaf后&#xff0c;会有一个默认的配置信息,可以在配置文件当中配置默认的信息&#xff0c;修改路径&#xff0c;前后缀等等参数 spring:thymeleaf…

华为OD机试 - 小华地图寻宝(Java JS Python C)

题目描述 小华按照地图去寻宝,地图上被划分成 m 行和 n 列的方格,横纵坐标范围分别是 [0, n-1] 和 [0, m-1]。 在横坐标和纵坐标的数位之和不大于 k 的方格中存在黄金(每个方格中仅存在一克黄金),但横坐标和纵坐标之和大于 k 的方格存在危险不可进入。小华从入口 (0,0) …

学习知识回顾随笔(远程连接MySQL|远程访问Django|HTTP协议|Web框架)

文章目录 如何远程连接MySQL数据库1.创建用户来运行&#xff0c;此用户从任何主机连接到mysql数据库2.使用IP地址来访问MySQL数据库 如何远程访问Django项目Web应用什么是Web应用应用程序的两种模式Web应用程序的优缺点 HTTP协议&#xff08;超文本传输协议&#xff09;简介HTT…

Airtest自动化测试工具实战演练

一开始知道Airtest大概是在年初的时候&#xff0c;当时&#xff0c;看了一下官方的文档&#xff0c;大概是类似Sikuli的一个工具&#xff0c;主要用来做游戏自动化的&#xff0c;通过截图的方式用来解决游戏自动化测试的难题。最近&#xff0c;移动端测试的同事尝试用它的poco库…

LCM-LoRA模型推理简明教程

潜在一致性模型 (LCM) 通常可以通过 2-4 个步骤生成高质量图像&#xff0c;从而可以在几乎实时的设置中使用扩散模型。 来自官方网站&#xff1a; LCM 只需 4,000 个训练步骤&#xff08;约 32 个 A100 GPU 小时&#xff09;即可从任何预训练的稳定扩散 (SD) 中提取出来&#…

sed文本 免交互

目录 什么是sed 概念 格式 基本用法 命令的选项 打印第三行 打印日志文件 打印奇数行 打印偶数行 第三行退出 删除第三行 sed在不打开文件的情况下修改文件内容 在后面添加 选项a 在字符中间添加 \n 实现追加换行 全部追加 在前面插入 选项i 替换 选项c …

HIVE SQL建表常用数据类型一览

类型描述BOOLEANtrue/falseTINYINTtrue/1字节的有符号整数 -128~127SMALLINT2个字节的有符号整数&#xff0c;-32768~32767INT4个字节的带符号整数BIGINT8字节带符号整数FLOAT4字节单精度浮点数DOUBLE8字节双精度浮点数DEICIMAL任意精度的带符号小数STRING字符串&#xff0c;变…

第二题-差值-【第六届传智杯程序设计挑战赛解题分析详解复盘】(JavaPythonC++实现)

🚀 欢迎来到 ACM 算法题库专栏 🚀 在ACM算法题库专栏,热情推崇算法之美,精心整理了各类比赛题目的详细解法,包括但不限于ICPC、CCPC、蓝桥杯、LeetCode周赛、传智杯等等。无论您是刚刚踏入算法领域,还是经验丰富的竞赛选手,这里都是提升技能和知识的理想之地。 ✨ 经典…

Java精品项目源码基于SpringBoot的智慧园区管理系统(v67)

Java精品项目源码基于SpringBoot的智慧园区管理系统(v67) 大家好&#xff0c;小辰今天给大家介绍一个智慧园区管理系统&#xff0c;演示视频公众号&#xff08;小辰哥的Java&#xff09;对号查询观看即可 文章目录 Java精品项目源码基于SpringBoot的智慧园区管理系统(v67)难度…

vmware系列:【VMware篇】8-vCenter的安装与配置(一)以IP地址安装

【VMware篇】8-vCenter的安装与配置(一)以IP地址安装 vmware系列文章链接第1章前言第2章安装前准备第3章安装步骤一、第一阶段二、打开主机shell、SSH三、添加域名解析四、第二阶段五、设置密码过期时间六、新建集群添加主机vmware系列文章链接 VMware官网下载注册: VMware…

【图像分割】【深度学习】PFNet官方Pytorch代码-PFNet网络损失函数模块解析

【图像分割】【深度学习】PFNet官方Pytorch代码-PFNet网络损失函数模块解析 文章目录 【图像分割】【深度学习】PFNet官方Pytorch代码-PFNet网络损失函数模块解析前言PM定位模块损失函数FM聚焦模块损失函数总结 前言 在详细解析PFNet代码之前&#xff0c;首要任务是成功运行PF…

压缩包文件丢失?4个正确找回方法分享!

“我有一个很重要的压缩包保存在电脑上&#xff0c;但是不知道为什么里面有些文件丢失了。有什么方法可以快速找回压缩文件&#xff1f;请大家给我支支招吧&#xff01;” 如果我们的文件太多&#xff0c;将它们放在压缩包中不仅能让文件更有序&#xff0c;还能更合理的节省电脑…

LD_PRELOAD劫持

LD_PRELOAD劫持 <1> LD_PRELOAD简介 LD_PRELOAD 是linux下的一个环境变量。用于动态链接库的加载&#xff0c;在动态链接库的过程中他的优先级是最高的。类似于 .user.ini 中的 auto_prepend_file&#xff0c;那么我们就可以在自己定义的动态链接库中装入恶意函数。 也…

tp8 使用rabbitMQ(3)发布/订阅

发布/订阅 当我们想把一个消息&#xff0c;发送给 多个消费者的时候&#xff0c;我们把这种模式叫做发布/订阅模式&#xff0c;比如我们做两个消费者&#xff0c;其中一个消费者把消息写入磁盘中&#xff0c;别一个消费者把消息结果输出到屏幕上&#xff0c;就要用到发布订阅模…