ref、isRef、toRef、toRefs、toRaw 看着一堆类似的东西,一个头两个大,今天整理一篇文章详细介绍它们的功能及区别。

1、ref

ref 属性除了能够获取元素外,也可以使用 ref 函数,创建一个响应式数据,当数据值发生改变时,视图自动更新。

  1. <script lang="ts" setup>
  2. import { ref } from 'vue'
  3. let str: string = ref('我是张三')
  4. const chang = () => {
  5. str.value = '我是钻石王老五'
  6. console.log(str.value)
  7. }
  8. </script>
  9. <template>
  10. <div>
  11. {{ str }}
  12. <button type="button" @click="chang">修改值</button>
  13. </div>
  14. </template>

2、isRef

检查变量是否为一个被 ref 包装过的对象,如果是返回 true ,否则返回 false。

  1. import { ref, isRef, reactive } from 'vue'
  2.  
  3. let str: string = ref('我是张三')
  4. let num: number = 1
  5. let per = reactive({ name: '代码女神', work: '程序媛' })
  6.  
  7. console.log('strRes', isRef(str)) //true
  8. console.log('numRes', isRef(num)) //false
  9. console.log('perRes', isRef(per)) //false

3、toRef

创建一个 ref 对象,其 value 值指向另一个对象中的某个属性。

toRef(obj, key) 将对象中的某个值转化为响应式数据,分为两种情况:

  • toRef 定义原始非响应式数据,修改值时,原始数据和 copy 数据都会变的,但是视图不更新。
  1. <script>
  2. import { ref, isRef, toRef, reactive } from 'vue'
  3. let obj = {
  4. name: '姓名',
  5. age: 18,
  6. }
  7. let name: string = toRef(obj, 'name')
  8. const chang = () => {
  9. obj.name = '钻石王老五'
  10. name.value = '李四'
  11. console.log(obj.name) // 李四
  12. console.log('name', name) // 李四
  13. }
  14. //chang() //DOM挂载前调用
  15. </script>
  16. <template>
  17. <div>
  18. {{ obj.name }} ------- {{ name }}
  19. <button type="button" @click="chang">修改值</button>
  20. </div>
  21. </template>

    注意:如果是在 DOM 挂载之前调用 chang 方法,改变数值,此时数据和视图都会发生改变。

  • toRef 定义原始数据响应式数据,修改值时,原始数据,和 copy 数据都会改变,视图也会更新。
  1. <script>
  2. import { ref, isRef, toRef, reactive } from 'vue'
  3. let obj = reactive({
  4. name: '姓名',
  5. age: 18,
  6. })
  7. let name: string = toRef(obj, 'name')
  8. const chang = () => {
  9. obj.name = '钻石王老五'
  10. name.value = '李四'
  11. }
  12. </script>
  13. <template>
  14. <div>
  15. {{ obj.name }} ------- {{ name }}
  16. <button type="button" @click="chang">修改值</button>
  17. </div>
  18. </template>

最终值为 “李四”。

4、toRefs

toRefs 用来解构 ref、reactive 包裹的响应式数据。接收一个对象作为参数,遍历对象上的所有属性,将对象上的所有属性变成响应式数据。

  1. let obj = reactive({
  2. name: '姓名',
  3. age: 18,
  4. })
  5. let { name, age } = toRefs(obj)
  6. const chang = () => {
  7. name.value = '钻石王老五'
  8. age.value++
  9. }
  10. </script>
  11. <template>
  12. <div>
  13. {{ name }} ------- {{ age }}
  14. <button type="button" @click="chang">修改值</button>
  15. </div>
  16. </template>

toRefs 解构数据时,如果某些参数作为可选参数,可选参数不存在时就会报错,如:

  1. let obj = reactive({
  2. name: '姓名',
  3. age: 18,
  4. })
  5. let { name, age, work } = toRefs(obj)
  6. const chang = () => {
  7. name.value = '钻石王老五'
  8. age.value++
  9. console.log('work', work.value)
  10. work.value = '程序媛'
  11. }

此时可以使用 toRef 解决此问题,使用 toRef 解构对象某个属性时,先检查对象上是否存在该属性,如果存在就继承对象上的属性值,如果不存在就会创建一个。

修改上边的代码为:

  1. let obj = reactive({
  2. name: '姓名',
  3. age: 18,
  4. })
  5. let { name, age } = toRefs(obj)
  6. let work = toRef(obj, 'work')
  7. const chang = () => {
  8. name.value = '钻石王老五'
  9. age.value++
  10. console.log('work', work.value)
  11. work.value = '程序媛'
  12. }

5、toRaw

将响应式对象转为原始对象。做一些不想被监听的事情,从 ref 或 reactive 得到原始数据。

修改原响应式数据时,toRaw 转换得到的数据会被修改,视图也会更新,如:

  1. <script lang="ts" setup>
  2. import { ref, isRef, toRef, toRefs, reactive, toRaw } from 'vue'
  3. let obj = reactive({
  4. name: '姓名',
  5. age: 18,
  6. })
  7. let newObj = toRaw(obj)
  8. const chang = () => {
  9. obj.name = '钻石王老五'
  10. obj.age++
  11. }
  12. </script>
  13. <template>
  14. <div>
  15. {{ obj.name }} ------- {{ obj.age }}
  16. <button type="button" @click="chang">修改值</button>
  17. <br />
  18. {{ newObj }}
  19. </div>
  20. </template>

如果修改 toRaw 得到的原始数据,原数据也会被修改,但是视图不更新。如:

  1. <script lang="ts" setup>
  2. import { ref, isRef, toRef, toRefs, reactive, toRaw } from 'vue'
  3. let obj = reactive({
  4. name: '姓名',
  5. age: 18,
  6. })
  7. let newObj = toRaw(obj)
  8. const chang = () => {
  9. obj.name = '钻石王老五'
  10. obj.age++
  11. }
  12. const changNew = () => {
  13. newObj.name = '搞笑'
  14. console.log('newObj', newObj)
  15. console.log('obj', obj)
  16. }
  17. </script>
  18. <template>
  19. <div>
  20. {{ obj.name }} ------- {{ obj.age }}
  21. <button type="button" @click="chang">修改值</button>
  22. <br />
  23. {{ newObj }}
  24. <button @click="changNew">修改</button>
  25. </div>
  26. </template>

vue3 的 ref、isRef、toRef、toRefs、toRaw 详细介绍的更多相关文章

  1. 全面了解Vue3的 ref 和相关函数和计算属性

    基础类型的响应性 -- ref 在vue3里面,我们可以通过 reactive 来实现引用类型的响应性,那么基础类型的响应性如何来实现呢? 可能你会想到这样来实现: const count = rea ...

  2. VUE3 之 ref、provide、inject 的使用 - 这个系列的教程通俗易懂,适合新手

    1. 概述 首因效应告诉我们: 在日常交往中,第一印象是非常重要的,好的第一印象能让我们在与人相处时事半功倍. 但也从另一面告诉我们,不能仅凭第一印象去判断一个人,有时虚假的第一印象,也有可能蒙蔽我们 ...

  3. linux配置网卡IP地址命令详细介绍及一些常用网络配置命令

    linux配置网卡IP地址命令详细介绍及一些常用网络配置命令2010-- 个评论 收藏 我要投稿 Linux命令行下配置IP地址不像图形界面下那么方 便,完全需要我们手动配置,下面就给大家介绍几种配置 ...

  4. 城市经纬度 json 理解SignalR Main(string[] args)之args传递的几种方式 串口编程之端口 多线程详细介绍 递归一个List<T>,可自己根据需要改造为通用型。 Sql 优化解决方案

    城市经纬度 json https://www.cnblogs.com/innershare/p/10723968.html 理解SignalR ASP .NET SignalR 是一个ASP .NET ...

  5. Spring BeanFactory与FactoryBean的区别及其各自的详细介绍于用法

    Spring BeanFactory与FactoryBean的区别及其各自的详细介绍于用法 1. BeanFactory BeanFactory,以Factory结尾,表示它是一个工厂类(接口),用于 ...

  6. awk 正则表达式、正则运算符详细介绍

    前言:使用awk作为文本处理工具,正则表达式是少不了的. 要掌握这个工具的正则表达式使用.其实,我们不必单独去学习它的正则表达式.正则表达式就像一门程序语言,有自己语法规则已经表示意思. 对于不同工具 ...

  7. [No0000A7]批处理经常用到的变量及批处理>NUL详细介绍

    绝对路径是指调用绝对的程序位置的路径,例如: start C:\Windows\test.exe 相对路径是文件改变路径以后还会按照变量的路径所在位置去调用,例如: start %WINDIR%\te ...

  8. _MSC_VER详细介绍

    _MSC_VER详细介绍 转自:http://www.cnblogs.com/braver/articles/2064817.html _MSC_VER是微软的预编译控制. _MSC_VER可以分解为 ...

  9. php CGI、Fastcgi、PHP-FPM的详细介绍与之间的关系

    以下PHP CGI.Fastcgi.PHP-FPM的一些信息归纳和汇总----->详细介绍与之间的关系 一:CGI是干嘛的?CGI是为了保证web server传递过来的数据是标准格式的 web ...

随机推荐

  1. Tapdata PDK 生态共建计划启动!Doris、OceanBase、PolarDB、SequoiaDB 等十余家厂商首批加入

      2022年4月7日,Tapdata 正式启动 PDK 插件生态共建计划,致力于全面连接数据孤岛,加速构建更加开放的数据生态,以期让各行各业的使用者都能释放数据的价值,随时获取新鲜的数据.截至目前, ...

  2. 攻防世界进阶区MISC ——56-60

    56.low 得到一张bmp,世纪之吻,扔进kali中,binwalk,zsteg,无果,再放进stegsolve中,虽然发现小的数据块,但是过滤通道得不到任何信息,猜测是要用脚本进行 # lsb隐写 ...

  3. java geteway 手机返回数据

    import lombok.extern.slf4j.Slf4j; import org.reactivestreams.Publisher; import org.springframework.c ...

  4. Mvcapi解决H5请求接口跨域问题

    using Newtonsoft.Json;using System;using System.Collections.Generic;using System.Linq;using System.N ...

  5. MQ系列2:消息中间件的技术选型

    1 背景 在高并发.高消息吞吐的互联网场景中,我们经常会使用消息队列(Message Queue)作为基础设施,在服务端架构中担当消息中转.消息削峰.事务异步处理 等职能. 对于那些不需要实时响应的的 ...

  6. 以三元组表为存储结构实现矩阵相加(耿5.7)----------西工大 noj

    #define _CRT_SECURE_NO_WARNINGS #include <stdio.h> #include <stdlib.h> #include <stri ...

  7. 西文字符与中文GBK编码的区别

    一般来讲二者读取的时候西文字符的数值是正,而中文字符的数值是负的,此时读取的是中文字符的前一半,需要再读取一个char类型的数据,在大多数运行环境下这个规则都是用. ps:转自算法竞赛的笔记,要注意在 ...

  8. vue2升级vue3:Vue Demij打通vue2与vue3壁垒,构建通用组件

    如果你的vue2代码之前是使用vue-class-component 类组件模式写的.选择可以使用 https://github.com/facing-dev/vue-facing-decorator ...

  9. 注解_概念和注解_JDK内置注解

    注解: 概念:说明程序的,给计算机看的 注解:用文字描述程序的,给程序员看的 定义:注解(Annotation),也叫元数据.一种代码级别的说明.他是JDK1.5及以后的版本引入的一个特性,与类,接口 ...

  10. 《Python编程:从入门到实践》第19章笔记:用户/用户注册/身份验证

    接上篇django最基本的一些日常用法,这是第19章笔记,希望在做"动手试一试"的时候可以让自己方便参考. 这一章实现了两个功能: 1.让用户能够添加主题Topic和条目Entry ...