vue3基础_toRef 和 toRefs

toRef 的使用

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


<script>
 import { reactive, toRef } from 'vue'
 export default {
   setup(){
    const obj = reactive({
      name:'ifer',
      age:10,
      address:'河南',
      sex:'男'
    }) 
  // 问题一:在模板中使用太麻烦了,每次都要obj.,重复!
  // 问题二:明明模板中只用到了name和age,你确把整个obj都导出了
  // 解构赋值会使响应式的数据丢失响应式,Proxy 包装的是整个对象,一旦进行了解构,相当于把对象中的普通值给了name、age变量
  // 把响应式对象obj中的 name 转成了响应式的 ref 数据
  const name = toRef(obj,'name')
  const age = toRef( obj,'age' )

   const updateName = () => {
   // 不要忘了 .value
      name.value = 'elser'
   // 转换后的name和原来的obj是关联的,意味着对原来数据的修改也会影响转换后的name
   // obj.name = 'elser'
   }
   return{
     name,age,updateName
   }

   }
   
  }
</script>

toRefs 的使用

在这里插入图片描述

toRefs 的最佳实践

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值