位置: IT常识 - 正文

【vue3】关于ref、toRef、toRefs那些事(vue3.0中的ref)

编辑:rootadmin
【vue3】关于ref、toRef、toRefs那些事

推荐整理分享【vue3】关于ref、toRef、toRefs那些事(vue3.0中的ref),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:vue3.0中的ref,vueref详解,vue3 ref用法,vue3使用$refs,vue3 ref dom,vue3使用$refs,vue3.0中的ref,vue3.0中的ref,内容如对您有帮助,希望把文章链接给更多的朋友!

😉博主:初映CY的前说(前端领域) 📒本文核心:ref、toRef、toRefs的使用方法

【前言】我们在上一节的学习当中,使用了reactive()函数将vue3中的数据变成响应式的数据,本文中所讲的三个方法也能实现将数据转化为响应式数据。话不多说,让我们来学习下这三个方法怎么用,以及与reactive的区别。

目录⭐一、ref⭐二、toRef⭐三、torefs⭐一、ref

ref 函数,可以把简单数据类型包裹为响应式数据(复杂类型也可以),注意 JS 中操作值的时候,需要加 .value 属性,模板中正常使用即可。 举个例子:

ref包装基本类型数据 App.vue<template> <div class="container"> <div>{{ name }}</div> <button @click="updateName">修改数据</button> </div></template><script> import { ref } from 'vue' export default { name: 'App', setup() { const name = ref('初映') const updateName = () => { name.value = '初映CY的前说' } return { name, updateName } }, }</script>

可看见写法与reactive()一样,不过是在js中书写的时候需要额外加一个.value即可

ref包装复杂类类型数据 注意:ref 其实也可以包裹复杂数据类型为响应式数据,一般对于数据类型未确定的情况下推荐使用 ref,例如后端返回的数据。<template> <div class="container"> <div>{{ data?.name }}</div> <button @click="updateName">修改数据</button> </div></template><script> import { ref } from 'vue' export default { name: 'App', setup() { // 初始值是 null const data = ref(null) setTimeout(() => { // 右边的对象可能是后端返回的 data.value = { name: '初映', } }, 1000) const updateName = () => { data.value.name = 'CY' } return { data, updateName } }, }</script>【vue3】关于ref、toRef、toRefs那些事(vue3.0中的ref)

如何选择? ref()和reactive()都是Vue.js3.0中提供的两个响应式API。 ref()主要用于创建一个响应式数据,它会将一个普通的JavaScript对象转换为一个响应式的对象,从而使数据的变化可以被Vue实例所追踪,当数据发生变化时,Vue会自动更新相关视图。ref()创建的响应式数据可以通过.value属性来访问和修改。 reactive()则主要用于创建一个响应式对象,可以用作包含多个值的状态对象,通常用于管理复杂的状态。它可以将一个普通的JavaScript对象转换为一个响应式对象,并且支持嵌套属性,即使嵌套属性发生变化也会被Vue实例所追踪。当响应式对象中有任何一个属性发生变化时,Vue也会自动更新相关的视图。 当你明确知道需要包裹的是一个对象,那么推荐使用 reactive,其他情况使用 ref 即可。 Vue3.2 之后,更推荐使用 ref,性能得到了很大的提升。⭐二、toRef

toRef 函数的作用:转换响应式对象中某个属性为单独响应式数据,并且转换后的值和之前是关联的(ref 函数也可以转换,但值非关联)。 先看下面这个例子:

<template> <div class="container"> <h2>name: {{ obj.name }} age: {{obj.age}}</h2> <button @click="updateName">修改数据</button> </div></template><script> import { reactive } from 'vue' export default { name: 'App', setup() { const obj = reactive({ name: '初映', age: 18, address: '江西', sex: '男', }) const updateName = () => { obj.name = '初映CY的前说' } return { obj, updateName } }, }</script>

这样写也可以将数据进行更改成为响应式的数据,但是带来了两个问题:

问题 1:模板中都要使用 obj. 进行获取数据,麻烦。

问题 2:明明模板中只用到了 name 和 age,却把整个 obj 进行了导出,没必要,性能浪费。

<template> <div class="container"> <h2>name: {{ name }} </h2> <button @click="updateName">修改数据</button> </div></template><script> import { reactive,toRef } from 'vue' export default { name: 'App', setup() { const obj = reactive({ name: '初映', age: 18, address: '江西', sex: '男', }) const name = toRef(obj, 'name') const updateName = () => { obj.name = '初映CY的前说' } return { name, updateName } }, }</script>

这样把我们需要的数据放进return即可,节约了性能与在模板中的写法,有点点了‘按需导入’的意思

⭐三、torefs

toRefs 函数的作用:转换响应式对象中所有属性为单独响应式数据,并且转换后的值和之前是关联的。

<template> <div class="container"> <h2>{{ name }} {{ age }}</h2> <button @click="updateName">修改数据</button> </div></template><script> import { reactive, toRefs } from 'vue' export default { name: 'App', setup() { const obj = reactive({ name: '初映', age: 10, }) const updateName = () => { obj.name = '初映CY的前说' obj.age = 18 } return { ...toRefs(obj), updateName } }, }</script>

toRefs将我们所有的响应式数据都进行return出去了,届时直接用上数据名称即可,记得加上…喔

至此本文结束,愿你有所收获! 期待大家的关注与支持! 你的肯定是我更新的最大动力!!!

本文链接地址:https://www.jiuchutong.com/zhishi/299775.html 转载请保留说明!

上一篇:使用Spring框架进行Web项目开发(初级)(使用spring框架,大概有哪些步骤)

下一篇:【自学前端】我只学这些够吗?好难(自学前端好学吗)

  • 一个身份证可以开几个抖音小店(一个身份证可以开两个房间吗?)

    一个身份证可以开几个抖音小店(一个身份证可以开两个房间吗?)

  • 华为p40有无线充电功能的吗(华为mate30无线充电)

    华为p40有无线充电功能的吗(华为mate30无线充电)

  • vivo x27指纹解锁在哪(vivo x27指纹解锁换屏了怎么不能用了)

    vivo x27指纹解锁在哪(vivo x27指纹解锁换屏了怎么不能用了)

  • 华为荣耀20对比华为荣耀v20(华为荣耀20对比20pro)

    华为荣耀20对比华为荣耀v20(华为荣耀20对比20pro)

  • 腾讯会议当前账号存在异常不允许登录(腾讯会议当前账号存在异常的界面)

    腾讯会议当前账号存在异常不允许登录(腾讯会议当前账号存在异常的界面)

  • 4g流量5g能用吗(4g流量5g手机能用么)

    4g流量5g能用吗(4g流量5g手机能用么)

  • 拦截呼叫转移来电是什么意思(拦截呼叫转移来电是什么功能)

    拦截呼叫转移来电是什么意思(拦截呼叫转移来电是什么功能)

  • main menu是什么基带(menu表示什么)

    main menu是什么基带(menu表示什么)

  • bd和hd视频的区别(hd和bd哪个清晰度高)

    bd和hd视频的区别(hd和bd哪个清晰度高)

  • 网易云最近播放在哪(网易云最近播放是实时的吗)

    网易云最近播放在哪(网易云最近播放是实时的吗)

  • 中塔和全塔机箱的区别(中塔和全塔机箱哪个好)

    中塔和全塔机箱的区别(中塔和全塔机箱哪个好)

  • 华为笔记本蓝屏重启不了(华为笔记本蓝屏怎么回事)

    华为笔记本蓝屏重启不了(华为笔记本蓝屏怎么回事)

  • 华为手机声音忽大忽小(华为手机声音忽然变小)

    华为手机声音忽大忽小(华为手机声音忽然变小)

  • 计算器mu键是什么意思(计算器按键m+)

    计算器mu键是什么意思(计算器按键m+)

  • 手机qq保存不了图片怎么回事(手机qq保存不了视频怎么回事)

    手机qq保存不了图片怎么回事(手机qq保存不了视频怎么回事)

  • 微信被投诉是正常用吗(微信被投诉是正常使用吗)

    微信被投诉是正常用吗(微信被投诉是正常使用吗)

  • 小米缓存数据可以清除吗(小米缓存数据可以删除吗)

    小米缓存数据可以清除吗(小米缓存数据可以删除吗)

  • 华为nova5pro有红外线吗(华为nova5pro有红外线遥控吗?)

    华为nova5pro有红外线吗(华为nova5pro有红外线遥控吗?)

  • 华为手机拍照怎么弄正方形(华为手机拍照怎么显示地理位置和时间)

    华为手机拍照怎么弄正方形(华为手机拍照怎么显示地理位置和时间)

  • xr突然黑屏开不了机(苹果xr突然黑屏没反应)

    xr突然黑屏开不了机(苹果xr突然黑屏没反应)

  • http代理怎么设置

    http代理怎么设置

  • 苹果mac怎么禁止某个应用联网?苹果mac禁止某个软件联网教程(苹果mac怎么禁止百度搜索)

    苹果mac怎么禁止某个应用联网?苹果mac禁止某个软件联网教程(苹果mac怎么禁止百度搜索)

  • 芬兰东部的Muje-Oulu湖 (© Topi Ylä-Mononen/plainpicture)(芬兰东部的国家有哪些)

    芬兰东部的Muje-Oulu湖 (© Topi Ylä-Mononen/plainpicture)(芬兰东部的国家有哪些)

  • 可解释深度学习:从感受野到深度学习的三大基本任务:图像分类,语义分割,目标检测,让你真正理解深度学习

    可解释深度学习:从感受野到深度学习的三大基本任务:图像分类,语义分割,目标检测,让你真正理解深度学习

  • 企业纳税信用等级评定标准
  • 增值税即征即退怎么计算
  • 扣缴义务人和纳税人举例
  • 出口关税税率表
  • 业务招待费和广告费扣除标准
  • 个人独资企业没有申报税的后果
  • 民营企业月末要报哪些税
  • 小企业准则汇兑损失计入什么科目
  • 可以不用附原始凭证的记账凭证是
  • 多交附加税怎么做会计分录
  • 分配股利需要缴纳个税吗
  • 外包业务账务处理
  • 装修行业一般纳税人税负率是多少
  • 增值税和增值税额的区别
  • 公司房租可以抵多少税
  • 盈余公积什么时候调整
  • 留抵退还增值税
  • 保险车辆折旧的计算方法有哪些
  • 抄报不了是怎么回事?
  • 建筑施工企业跨区域如何缴税
  • 美元兑人民币分时走势图
  • 支付境外特许权许可使用费资料
  • 怎么升级win11正版
  • 华为鸿蒙harmonyos刷机
  • win10应用商店没有软件库
  • PSof1.exe - PSof1是什么进程 有什么作用
  • 境外人员定义
  • 苹果语音备忘录怎么导出
  • 增值税发票没认证 可以重新开吗
  • 脐橙产业可行性报告
  • 外国企业如何在阿联酋注册商标
  • 财税〔2017〕34号文件中提到的科技型中小企业是指哪种企业?
  • 营改增后酒店行业有哪些税种
  • 预算超支怎么办
  • php实现图片上传到网页显示
  • ci框架api版本
  • chrome安装教程
  • 银行历年账单怎么查
  • 如何用php
  • thinkphp项目怎么运行
  • vue跨域的几种方式
  • 拨入专款年终如何做账
  • 承兑汇票怎么使用流程
  • 税控服务费电子普票能抵扣吗
  • mysql 中文排序是什么规则
  • 主营业务成本大于主营业务收入怎么办
  • 增值税少企业所得税高吗
  • 财务挂账应该怎么做账
  • 房地产项目公司组织架构
  • 支付的物业费如何做账
  • 个人开技术服务费
  • 上年折旧没提今年可以补提吗
  • 工地会计怎么做账
  • 会议费报销时应当提供哪些材料
  • 银行回单模板
  • 公交充值卡发票能报销吗
  • 公司抽奖的成本怎么算
  • sql语句查询去重
  • Mysql使用教程
  • 根据日期算时间
  • windows u盘制作
  • c盘满了怎么释放空间
  • macos卸载java
  • macbook做热点
  • u盘安装win7视频教程
  • windowsxp的安装方法
  • U盘写保护怎么处理
  • exgear是什么
  • mac未能分区
  • win7 设置
  • 老生常谈的近义词
  • 比较漂亮的一个字
  • js响应式布局
  • python闭包的条件
  • javascript设置字体
  • css实现3d效果
  • 安徽省马鞍山地区代码
  • 水利建设基金如何计提
  • 税务纪检部门
  • 房地产开发企业资质管理规定
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设