位置: 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框架,大概有哪些步骤)

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

  • 行政法律法规是规定行政机关
  • 受让应收账款的账务处理
  • 其他权益工具投资公允价值变动
  • 主营业务收入体现在资产负债表哪里
  • 出口退税进项发票认证勾选
  • 一般纳税人收到普票需要价税分离吗
  • 电子产品配件批发市场
  • 增值税专票逾期抵扣怎么操作
  • 专项资金可以存定期吗
  • 个人所得税申报方式选哪个比较好
  • 土地增值税计税依据
  • 旅行社代订机票发票写个人能报销吗
  • 中国公司可以给境外公司开发票吗
  • 包销和代销哪个风险大
  • 个税和实发不一样
  • 公司承担的个人所得税怎么做分录
  • 损益类科目包括收入类和费用类么
  • 产业扶持周转金退回多久到账
  • 来料加工企业如何计算产值
  • 营改增后不动产发票样本
  • 服装具有什么性
  • 融资租赁增值税优惠政策
  • 餐饮业现金流
  • 购房发票拿到了接着干什么
  • 增值税四个税种
  • 房产证工本费怎么做账
  • 索尼笔记本电脑官网
  • 前期做了无票收入,后期怎么填写
  • 增值税留抵退税账务处理
  • kb4586853更新
  • php i
  • php bi
  • 个人将房产过户到一人有限公司交什么税
  • 大堡礁分布在澳大利亚的哪里
  • 非正常损失可以税前扣除吗
  • php exec python
  • 长投转可供
  • 企业交的社保包含什么
  • mysql 5.7.20 win64 安装及配置方法
  • 印花税核定征收比例取消了吗
  • 电子发票查询真伪
  • 财务报表的填写要求
  • SQL 2005 ERROR:3145 解决办法(备份集中的数据库备份与现有的数据库不同)
  • 分配水电费会计科目
  • 哪些情况可以开立基本账户
  • 去年多计提的所得税怎么处理
  • 预提费用为什么是负债
  • 控股合并和吸收合并会计处理的区别
  • 存货计提存货跌价准备
  • 高速过路费怎么补交
  • 公司运营成本如何计算
  • 理财利息计入什么科目
  • 红字发票可以跨月入账吗
  • 餐饮开票税率
  • 进项发票已入账进项税,但是未抵扣怎么办
  • 非正常损失的进项税额转出会计分录
  • 收到一笔财政局的付款
  • 会务费可以抵扣进项税额吗
  • 延期支票可以撤回吗
  • 总账的建立
  • Linux下MySQL 5.6.27 安装教程
  • mysql无法配置
  • sql字段转首字母大写
  • win10玩魔兽争霸卡顿
  • awk 筛选有特定字符
  • win8 桌面图标
  • mac验证码无法显示怎么办
  • 如何延长mac待机时间
  • win7系统打印服务怎么开启
  • win8找不到恢复环境怎么恢复出厂设置
  • win8怎么更新到win8.1
  • 搭建android开发环境需要用到哪些工具
  • cocos2d android 游戏开发学习——CCAction(二)
  • cocos3.0
  • jQuery使用animate实现ul列表项相互飘动效果示例
  • 教大家使用灭火器
  • python操作mongodb数据库
  • 青岛税务局网上办税厅app
  • 食堂增值服务有哪些
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设