vue3 的 ref、isRef、toRef、toRefs、toRaw 详细介绍
ref、isRef、toRef、toRefs、toRaw 看着一堆类似的东西,一个头两个大,今天整理一篇文章详细介绍它们的功能及区别。
1、ref
ref 属性除了能够获取元素外,也可以使用 ref 函数,创建一个响应式数据,当数据值发生改变时,视图自动更新。
- <script lang="ts" setup>
- import { ref } from 'vue'
- let str: string = ref('我是张三')
- const chang = () => {
- str.value = '我是钻石王老五'
- console.log(str.value)
- }
- </script>
- <template>
- <div>
- {{ str }}
- <button type="button" @click="chang">修改值</button>
- </div>
- </template>
2、isRef
检查变量是否为一个被 ref 包装过的对象,如果是返回 true ,否则返回 false。
- import { ref, isRef, reactive } from 'vue'
- let str: string = ref('我是张三')
- let num: number = 1
- let per = reactive({ name: '代码女神', work: '程序媛' })
- console.log('strRes', isRef(str)) //true
- console.log('numRes', isRef(num)) //false
- console.log('perRes', isRef(per)) //false
3、toRef
创建一个 ref 对象,其 value 值指向另一个对象中的某个属性。
toRef(obj, key) 将对象中的某个值转化为响应式数据,分为两种情况:
- toRef 定义原始非响应式数据,修改值时,原始数据和 copy 数据都会变的,但是视图不更新。
- <script>
- import { ref, isRef, toRef, reactive } from 'vue'
- let obj = {
- name: '姓名',
- age: 18,
- }
- let name: string = toRef(obj, 'name')
- const chang = () => {
- obj.name = '钻石王老五'
- name.value = '李四'
- console.log(obj.name) // 李四
- console.log('name', name) // 李四
- }
- //chang() //DOM挂载前调用
- </script>
- <template>
- <div>
- {{ obj.name }} ------- {{ name }}
- <button type="button" @click="chang">修改值</button>
- </div>
- </template>
注意:如果是在 DOM 挂载之前调用 chang 方法,改变数值,此时数据和视图都会发生改变。
- toRef 定义原始数据响应式数据,修改值时,原始数据,和 copy 数据都会改变,视图也会更新。
- <script>
- import { ref, isRef, toRef, reactive } from 'vue'
- let obj = reactive({
- name: '姓名',
- age: 18,
- })
- let name: string = toRef(obj, 'name')
- const chang = () => {
- obj.name = '钻石王老五'
- name.value = '李四'
- }
- </script>
- <template>
- <div>
- {{ obj.name }} ------- {{ name }}
- <button type="button" @click="chang">修改值</button>
- </div>
- </template>
最终值为 “李四”。
4、toRefs
toRefs 用来解构 ref、reactive 包裹的响应式数据。接收一个对象作为参数,遍历对象上的所有属性,将对象上的所有属性变成响应式数据。
- let obj = reactive({
- name: '姓名',
- age: 18,
- })
- let { name, age } = toRefs(obj)
- const chang = () => {
- name.value = '钻石王老五'
- age.value++
- }
- </script>
- <template>
- <div>
- {{ name }} ------- {{ age }}
- <button type="button" @click="chang">修改值</button>
- </div>
- </template>
toRefs 解构数据时,如果某些参数作为可选参数,可选参数不存在时就会报错,如:
- let obj = reactive({
- name: '姓名',
- age: 18,
- })
- let { name, age, work } = toRefs(obj)
- const chang = () => {
- name.value = '钻石王老五'
- age.value++
- console.log('work', work.value)
- work.value = '程序媛'
- }
此时可以使用 toRef 解决此问题,使用 toRef 解构对象某个属性时,先检查对象上是否存在该属性,如果存在就继承对象上的属性值,如果不存在就会创建一个。
修改上边的代码为:
- let obj = reactive({
- name: '姓名',
- age: 18,
- })
- let { name, age } = toRefs(obj)
- let work = toRef(obj, 'work')
- const chang = () => {
- name.value = '钻石王老五'
- age.value++
- console.log('work', work.value)
- work.value = '程序媛'
- }
5、toRaw
将响应式对象转为原始对象。做一些不想被监听的事情,从 ref 或 reactive 得到原始数据。
修改原响应式数据时,toRaw 转换得到的数据会被修改,视图也会更新,如:
- <script lang="ts" setup>
- import { ref, isRef, toRef, toRefs, reactive, toRaw } from 'vue'
- let obj = reactive({
- name: '姓名',
- age: 18,
- })
- let newObj = toRaw(obj)
- const chang = () => {
- obj.name = '钻石王老五'
- obj.age++
- }
- </script>
- <template>
- <div>
- {{ obj.name }} ------- {{ obj.age }}
- <button type="button" @click="chang">修改值</button>
- <br />
- {{ newObj }}
- </div>
- </template>
如果修改 toRaw 得到的原始数据,原数据也会被修改,但是视图不更新。如:
- <script lang="ts" setup>
- import { ref, isRef, toRef, toRefs, reactive, toRaw } from 'vue'
- let obj = reactive({
- name: '姓名',
- age: 18,
- })
- let newObj = toRaw(obj)
- const chang = () => {
- obj.name = '钻石王老五'
- obj.age++
- }
- const changNew = () => {
- newObj.name = '搞笑'
- console.log('newObj', newObj)
- console.log('obj', obj)
- }
- </script>
- <template>
- <div>
- {{ obj.name }} ------- {{ obj.age }}
- <button type="button" @click="chang">修改值</button>
- <br />
- {{ newObj }}
- <button @click="changNew">修改</button>
- </div>
- </template>
vue3 的 ref、isRef、toRef、toRefs、toRaw 详细介绍的更多相关文章
- 全面了解Vue3的 ref 和相关函数和计算属性
基础类型的响应性 -- ref 在vue3里面,我们可以通过 reactive 来实现引用类型的响应性,那么基础类型的响应性如何来实现呢? 可能你会想到这样来实现: const count = rea ...
- VUE3 之 ref、provide、inject 的使用 - 这个系列的教程通俗易懂,适合新手
1. 概述 首因效应告诉我们: 在日常交往中,第一印象是非常重要的,好的第一印象能让我们在与人相处时事半功倍. 但也从另一面告诉我们,不能仅凭第一印象去判断一个人,有时虚假的第一印象,也有可能蒙蔽我们 ...
- linux配置网卡IP地址命令详细介绍及一些常用网络配置命令
linux配置网卡IP地址命令详细介绍及一些常用网络配置命令2010-- 个评论 收藏 我要投稿 Linux命令行下配置IP地址不像图形界面下那么方 便,完全需要我们手动配置,下面就给大家介绍几种配置 ...
- 城市经纬度 json 理解SignalR Main(string[] args)之args传递的几种方式 串口编程之端口 多线程详细介绍 递归一个List<T>,可自己根据需要改造为通用型。 Sql 优化解决方案
城市经纬度 json https://www.cnblogs.com/innershare/p/10723968.html 理解SignalR ASP .NET SignalR 是一个ASP .NET ...
- Spring BeanFactory与FactoryBean的区别及其各自的详细介绍于用法
Spring BeanFactory与FactoryBean的区别及其各自的详细介绍于用法 1. BeanFactory BeanFactory,以Factory结尾,表示它是一个工厂类(接口),用于 ...
- awk 正则表达式、正则运算符详细介绍
前言:使用awk作为文本处理工具,正则表达式是少不了的. 要掌握这个工具的正则表达式使用.其实,我们不必单独去学习它的正则表达式.正则表达式就像一门程序语言,有自己语法规则已经表示意思. 对于不同工具 ...
- [No0000A7]批处理经常用到的变量及批处理>NUL详细介绍
绝对路径是指调用绝对的程序位置的路径,例如: start C:\Windows\test.exe 相对路径是文件改变路径以后还会按照变量的路径所在位置去调用,例如: start %WINDIR%\te ...
- _MSC_VER详细介绍
_MSC_VER详细介绍 转自:http://www.cnblogs.com/braver/articles/2064817.html _MSC_VER是微软的预编译控制. _MSC_VER可以分解为 ...
- php CGI、Fastcgi、PHP-FPM的详细介绍与之间的关系
以下PHP CGI.Fastcgi.PHP-FPM的一些信息归纳和汇总----->详细介绍与之间的关系 一:CGI是干嘛的?CGI是为了保证web server传递过来的数据是标准格式的 web ...
随机推荐
- Tapdata PDK 生态共建计划启动!Doris、OceanBase、PolarDB、SequoiaDB 等十余家厂商首批加入
2022年4月7日,Tapdata 正式启动 PDK 插件生态共建计划,致力于全面连接数据孤岛,加速构建更加开放的数据生态,以期让各行各业的使用者都能释放数据的价值,随时获取新鲜的数据.截至目前, ...
- 攻防世界进阶区MISC ——56-60
56.low 得到一张bmp,世纪之吻,扔进kali中,binwalk,zsteg,无果,再放进stegsolve中,虽然发现小的数据块,但是过滤通道得不到任何信息,猜测是要用脚本进行 # lsb隐写 ...
- java geteway 手机返回数据
import lombok.extern.slf4j.Slf4j; import org.reactivestreams.Publisher; import org.springframework.c ...
- Mvcapi解决H5请求接口跨域问题
using Newtonsoft.Json;using System;using System.Collections.Generic;using System.Linq;using System.N ...
- MQ系列2:消息中间件的技术选型
1 背景 在高并发.高消息吞吐的互联网场景中,我们经常会使用消息队列(Message Queue)作为基础设施,在服务端架构中担当消息中转.消息削峰.事务异步处理 等职能. 对于那些不需要实时响应的的 ...
- 以三元组表为存储结构实现矩阵相加(耿5.7)----------西工大 noj
#define _CRT_SECURE_NO_WARNINGS #include <stdio.h> #include <stdlib.h> #include <stri ...
- 西文字符与中文GBK编码的区别
一般来讲二者读取的时候西文字符的数值是正,而中文字符的数值是负的,此时读取的是中文字符的前一半,需要再读取一个char类型的数据,在大多数运行环境下这个规则都是用. ps:转自算法竞赛的笔记,要注意在 ...
- vue2升级vue3:Vue Demij打通vue2与vue3壁垒,构建通用组件
如果你的vue2代码之前是使用vue-class-component 类组件模式写的.选择可以使用 https://github.com/facing-dev/vue-facing-decorator ...
- 注解_概念和注解_JDK内置注解
注解: 概念:说明程序的,给计算机看的 注解:用文字描述程序的,给程序员看的 定义:注解(Annotation),也叫元数据.一种代码级别的说明.他是JDK1.5及以后的版本引入的一个特性,与类,接口 ...
- 《Python编程:从入门到实践》第19章笔记:用户/用户注册/身份验证
接上篇django最基本的一些日常用法,这是第19章笔记,希望在做"动手试一试"的时候可以让自己方便参考. 这一章实现了两个功能: 1.让用户能够添加主题Topic和条目Entry ...