返回顶部
首页 > 资讯 > 精选 >Vue3中toRef和toRefs函数如何使用
  • 779
分享到

Vue3中toRef和toRefs函数如何使用

2023-07-06 13:07:03 779人浏览 泡泡鱼
摘要

这篇文章主要介绍了vue3中toRef和toRefs函数如何使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Vue3中toRef和toRefs函数如何使用文章都会有所收获,下面我们一起来看看吧。toRef 函

这篇文章主要介绍了vue3中toRef和toRefs函数如何使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Vue3中toRef和toRefs函数如何使用文章都会有所收获,下面我们一起来看看吧。

toRef 函数使用

首先呢, toRef 函数有两个参数。

toRef(操作对象, 对象属性)

好,接下来我们使用 toRef 函数写一个案例,还是和以前一样,页面展示一个用户的名称和年纪。

<template>  <div>    <h3>toRef toRefs 函数</h3>    <p>姓名:{{boy_toRef}}</p>    <p>年龄:{{boy.age}}</p>  </div></template><script>  import { toRef } from 'vue'  export default {    setup() {      const boy = {   // 创建一个用户对象        name: '我是????????.',   // 用户名称        age: 10    // 用户年龄      }      // 使用 toRef 函数包裹,操作 boy 对象的 name 属性      const boy_toRef = toRef(boy, 'name')        console.log(boy_toRef)  // 我们直接打印看一下包裹后的数据格式      return { boy, boy_toRef }    }  }</script>

保存代码,刷新页面。

Vue3中toRef和toRefs函数如何使用

我们可以看到数据的结构,在 value 里面直接就是 boy 下面 name 的属性值,所以说,接下来我们编写一个按钮,点击按钮,修改这个 name 值。

<template>  <div>    <h3>toRef toRefs 函数</h3>    <p>姓名:{{boy_toRef}}</p>    <p>年龄:{{boy.age}}</p>    <el-button type="primary" @click="btn">修改 name</el-button>  </div></template><script>  import { toRef } from 'vue'  export default {    setup() {      const boy = {        name: '我是????????.',        age: 10      }      // 这个 boy_toRef 就是被 toRef 函数操作过的 boy 的 name 值      const boy_toRef = toRef(boy, 'name')        const btn = () => {        boy_toRef.value = '????????.'  // 把 name 修改成 ????????.        console.log(boy_toRef)   // 修改完成打印一下结果      }      return { boy, btn, boy_toRef }    }  }</script>

保存代码刷新页面,然后点击按钮看一下页面效果。

Vue3中toRef和toRefs函数如何使用

通过截图展示的效果我们可以发现,boy_toRef 的值确实被修改了,但是呢,页面并没有改变,而且页面也没有出现错误。

这是什么原因呢? 其实这不是 Bug 哈,在本篇博文开始就说过,toRef 函数会与源数据交互,修改响应式数据会造成源数据的修改,但是他的修改不会造成视图层数据的更新,所以说,这就是 toRef 函数的功能。确实,视图没有数据更新我们通过上面的截图看到了,但是源数据修改这个怎么看呢?没关系,在回答这个问题之前,我们首先得知道,什么是源数据。

就像上面的代码:

const boy = {  name: '我是????????.',  age: 10}const boy_toRef = toRef(boy, 'name')

toRef 函数将 boy 对象给包裹了起来,所以说,boy 对象就是源数据。

因此,若想确认原始数据是否已更改,需在按钮点击后打印boy对象并观察是否已更改。

<template>  <div>    <h3>toRef toRefs 函数</h3>    <p>姓名:{{boy_toRef}}</p>    <p>年龄:{{boy.age}}</p>    <el-button type="primary" @click="btn">修改 name</el-button>  </div></template><script>  import { toRef } from 'vue'  export default {    setup() {      const boy = {        name: '我是????????.',        age: 10      }      const boy_toRef = toRef(boy, 'name')  // 这个 boy_toRef 就是被 toRef 函数操作过的 boy 的 name 值      const btn = () => {        boy_toRef.value = '????????.'  // 把 name 修改成 ????????.        console.log(boy_toRef)   // 修改完成打印一下结果        console.log(boy)   // 修改完成打印一下boy结果      }      return { boy, btn, boy_toRef }    }  }</script>

保存代码,刷新页面,在点击按钮修改 name 值,然后查看一下控制台打印的 boy 对象。

Vue3中toRef和toRefs函数如何使用

发现 boy 对象的 name 值已经从 我是????????. 改为 ????????.了,但是页面依旧没有更新。

记住了!

toRef 函数会与源数据交互,修改响应式数据会造成源数据的修改,但是他的修改不会造成视图层数据的更新。

ref 函数验证

那 ref 函数可以将对象里面的属性值变成响应式的数据,修改响应式数据,是不会影响到源数据,但是视图层上的数据会被更新 这句话是正确的嘛?

我们还是写一个案例,页面展示一个名称,点击按钮,修改页面名称。

<template>  <div>    <h3>ref Reactive 函数</h3>    <p>姓名:{{name_ref}}</p>    <el-button type="primary" @click="btn">修改信息</el-button>  </div></template><script>  import { ref } from 'vue'  export default {    setup() {      const name = '我是????????.'      const name_ref = ref(name)      const btn = () => {        name_ref.value = '????????.'        console.log(name_ref)  // 打印一下被ref包裹的数据        console.log(name)   // 打印一下源数据      }      return { name_ref, btn }    }  }</script>

保存代码,刷新页面,点击按钮查看页面控制台打印的结果,主要是看一下被 ref 函数包裹后的数据有没有修改成功,源数据有没有修改成功,最后页面有没有修改,下面看截图。

Vue3中toRef和toRefs函数如何使用

OK,通过上面截图,顾忌大家都理解了吧!

所以再记住!

ref 函数可以将对象里面的属性值变成响应式的数据,修改响应式数据,是不会影响到源数据,但是视图层上的数据会被更新

toRefs 函数

toRefs 函数的使用呢,其实和 toRef 函数类似的哈。

  • toRefs 函数用于批量设置多个数据为相应是数据。

  • toRefs 函数与原始数据相交互,修改响应式数据会影响到源数据,但是不会更新视图层。

  • toRefs 函数还可以与其他响应式数据相交互,更加方便处理视图层数据。

toRefs 函数使用

老样子,创建一个对象,然后使用 toRefs 函数包裹,在页面展示一下。

<template>  <div>    <h3>toRef toRefs 函数</h3>    <p>姓名:{{boy_toRefs.name}}</p>    <p>年龄:{{boy_toRefs.age}}</p>  </div></template><script>  import { toRefs } from 'vue'  export default {    setup() {      const boy = {        name: '我是????????.',        age: 10      }      const boy_toRefs = toRefs(boy)   // 将 boy 用 toRefs 包裹      console.log(boy_toRefs)   // 打印一下结果      return { boy_toRefs }    }  }</script>

保存代码,刷新页面查看。

Vue3中toRef和toRefs函数如何使用

所以说,我们修改修改一下代码,在渲染的时候除了 .属性 之外,还需要 .value。

    <p>姓名:{{boy_toRefs.name.value}}</p>    <p>年龄:{{boy_toRefs.age.value}}</p>

把视图层代码修改一下,然后查看效果。

Vue3中toRef和toRefs函数如何使用

诶,现在就是正常的啦!

有人可能会疑问,那这玩意儿整的不是越来越复杂了吗?本来直接点属性就可以,现在还得点属性点value,不是多此一举,脱裤子放P吗? 嘿嘿嘿!我觉得也是。

为什么呢说是多此一举也很正常,因为前面的博文讲过,这种复杂结构数据我们完全可以使用 reactive 函数来处理呀,渲染最多点一次就可以,但是 toRefs 函数却需要点两次。

<template>  <div>    <h3>toRef toRefs 函数</h3>    <p>姓名:{{boy_toRefs.name}}</p>    <p>年龄:{{boy_toRefs.age}}</p>  </div></template><script>  import { toRefs, reactive } from 'vue'  export default {    setup() {      const boy = {        name: '我是????????.',        age: 10      }      const boy_toRefs = reactive(boy)      return { boy_toRefs }    }  }</script>

我们不使用 toRefs 函数,而是用之前说的 reactive 函数处理数据。

Vue3中toRef和toRefs函数如何使用

我们可以看到,页面是可以正常解析的,那为什么我们还有舍近求远的使用 toRefs 函数呢?

其实是有原因的呀!

其实 toRefs 函数最大的用处在这里!

我们这个 boy 对象里面只有两个参数比较少,如果我们这个对象里面有十个参数或者是更多的话,每次展示的时候都得写那么多遍的 boy 点,是不是很麻烦呢?所以说使用 toRefs 函数就可以解决这个问题,看下面的代码。

<template>  <div>    <h3>toRef toRefs 函数</h3>    <p>姓名:{{name}}</p>    <p>年龄:{{age}}</p>  </div></template><script>  import { toRefs } from 'vue'  export default {    setup() {      const boy = {        name: '我是????????.',        age: 10      }      return { boy_toRefs , ...toRefs(boy)}    }  }</script>

在 return 抛出 reactive 的时候,使用扩展运算符和 toRefs 函数,就可以实现直接写属性的方式展示数据了。

Vue3中toRef和toRefs函数如何使用

但是呢,深层次的对象依旧需要通过点来实现。

也许你还有疑问,直接扩展运算 reactive 函数也行啊,为啥要套上 toRefs 函数,记住一点呀!

toRefs 函数修改,原始数据被改变,页面不会被触发。

看下面代码:

<template>  <div>    <h3>toRef toRefs 函数</h3>    <p>姓名:{{name}}</p>    <p>年龄:{{age}}</p>    <el-button type="primary" @click="btn">修改 name</el-button>  </div></template><script>  import { toRefs, reactive } from 'vue'  export default {    setup() {      const boy = {        name: '我是????????.',        age: 10      }      const new_toRefs = toRefs(boy)      const btn = () => {        new_toRefs.name.value = '????????.'        console.log(boy)      }      return { btn, ...toRefs(boy) }    }  }</script>

打印一下结果:

Vue3中toRef和toRefs函数如何使用

从打印结果中可以看出,原始数据被改变,页面没有被触发。根据我的写法,可以发现,从解构或构建 toRefs 返回的对象,都不会对值的响应性产生影响。

关于“Vue3中toRef和toRefs函数如何使用”这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对“Vue3中toRef和toRefs函数如何使用”知识都有一定的了解,大家如果还想学习更多知识,欢迎关注编程网精选频道。

--结束END--

本文标题: Vue3中toRef和toRefs函数如何使用

本文链接: https://lsjlt.com/news/358469.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Vue3中toRef和toRefs函数如何使用
    这篇文章主要介绍了Vue3中toRef和toRefs函数如何使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Vue3中toRef和toRefs函数如何使用文章都会有所收获,下面我们一起来看看吧。toRef 函...
    99+
    2023-07-06
  • Vue3中toRef和toRefs函数怎么使用
    好,接下来我们使用 toRef 函数写一个案例,还是和以前一样,页面展示一个用户的名称和年纪。<template> <div> <h2>toRef toRefs 函数</h2> ...
    99+
    2023-05-16
    Vue3 toref torefs
  • vue3 中的toRef函数和toRefs函数的基本使用
    目录这篇我们看下toRef和toRefs的基本使用Vue3的toRef这篇我们看下toRef和toRefs的基本使用 我们知道ref可以用于创建一个响应式数据,而toRef也可以创建...
    99+
    2022-11-16
    vue3 toRef和toRefs函数 vue3 toRef函数和toRefs函数 vue3 toRef函数
  • 一文搞懂Vue3中toRef和toRefs函数的使用
    目录toRef 函数toRef 函数使用ref 函数验证toRefs 函数toRefs 函数使用总结上一篇博文介绍了 vue3 里面的 ref 函数和 reactive 函数,实现响...
    99+
    2024-04-02
  • Vue3中的toRef和toRefs怎么使用
    今天小编给大家分享一下Vue3中的toRef和toRefs怎么使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。toRef ...
    99+
    2023-07-05
  • Vue的toRef、toRefs和toRaw函数如何使用
    今天小编给大家分享一下Vue的toRef、toRefs和toRaw函数如何使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。...
    99+
    2023-07-05
  • vue3中的ref、toRef、toRefs怎么使用
    这篇文章主要讲解了“vue3中的ref、toRef、toRefs怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“vue3中的ref、toRef、toRefs怎么使用”吧!一、refre...
    99+
    2023-07-06
  • Vue3响应式函数对比:toRef() vs toRefs()
    ref是处理基本数据类型响应式API函数,在setup中声明定义的变量,可以直接在模板中使用没有被响应式API包裹处理的变量数据,是不具备响应式能力的也就是往往在逻辑中修改了数据,但是页面不会更新,那怎么样将一个非响应式数据变成响应式数据就...
    99+
    2023-05-14
    javascript Vue
  • VueJs中toRef与toRefs函数怎么使用
    这篇文章主要介绍了VueJs中toRef与toRefs函数怎么使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇VueJs中toRef与toRefs函数怎么使用文章都会有所收获,下面我们一起来看看吧。正文ref...
    99+
    2023-07-05
  • Vue3中ref toRef和toRefs的区别有哪些
    这篇文章主要为大家展示了“Vue3中ref toRef和toRefs的区别有哪些”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Vue3中ref toRef和toRefs的区别...
    99+
    2023-06-22
  • 浅谈vue3中ref、toRef、toRefs 和 reactive的区别
    目录一、ref——定义任意类型响应式数据二、reactive——定义响应式对象三、toRef——将一个 rea...
    99+
    2024-04-02
  • 一文带你了解Vue3中toRef和toRefs的用法
    toRef 顾名思义,不是ref 响应式数据,给它转成ref 响应式数据 通俗易懂的理解: <template> <h3>姓名:{{ pers...
    99+
    2023-01-30
    Vue3 toRef toRefs用法 Vue3 toRef toRefs
  • Vue3响应式函数toRef()对比toRefs()源码分析
    今天小编给大家分享一下Vue3响应式函数toRef()对比toRefs()源码分析的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下...
    99+
    2023-07-05
  • vue3中的ref,toRef,toRefs三个的作用使用小结
    目录1. ref的使用2. toRef的使用3. toRefs的使用4.总结1. ref的使用      ref 接受一个原始值,返回一个具有响应式的对...
    99+
    2022-11-16
    vue3 ref toRef toRefs vue3 ref toRef toRefs区别
  • VueJs中toRef与toRefs函数对比详解
    目录正文toRef()函数与ref的不同toRefs()函数为啥需要toRef()与toRefs()函数总结正文 ref是处理基本数据类型响应式API函数,在setup中声明定义的...
    99+
    2023-03-15
    VueJs toRef与toRefs函数对比 VueJs toRef toRefs
  • Vue中的ref、toRef与toRefs怎么使用
    这篇文章主要介绍了Vue中的ref、toRef与toRefs怎么使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Vue中的ref、toRef与toRefs怎么使用文章都会有所收获,下面我们一起来看看吧。一、r...
    99+
    2023-07-05
  • Vue3中reactive函数toRef函数ref函数简介
    目录reactive函数用法:toRef函数(了解即可)用法:ref函数定义响应式数据直接定义使用获取dom获取组件实例对象reactive函数 reactive用于定义响应式数据(...
    99+
    2024-04-02
  • Vue3如何理解reftoRef和toRefs的区别
    目录一、基础 1.ref 2.toRef3.toRefs4.最佳的使用方式二、深入 1.为什么需要ref2.ref为什么需要.value3.为什么需要toRef和toRefsVue3...
    99+
    2024-04-02
  • vue3中的setup函数如何使用
    这篇文章主要讲解了“vue3中的setup函数如何使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“vue3中的setup函数如何使用”吧!概述 一、 初识setup函数 ...
    99+
    2023-06-30
  • Vue3中的h函数如何使用
    HelloWorld.vue<script setup lang="ts"> import { ref } from 'vue'; const param = ref("Hello...
    99+
    2023-05-14
    Vue3
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作