ref、toRef、和toRefs的区别

文章详细介绍了Vue中ref、toRef和toRefs的用法和区别。ref创建的是响应式副本,修改不影响原始数据;toRef保持与原始数据的引用关系,修改响应式数据会反映到原始数据;toRefs则用于批量将对象属性转为响应式且与原始数据关联,但更新不触发UI更新。此外,toRefs有助于解决return变量过多的问题。
摘要由CSDN通过智能技术生成

ref

import { ref } from 'vue';
export default {
  name:'App'
  setup(){
    let obj = {name : 'alice', age : 12};
    let newObj= ref(obj.name);
    const change = () => {
      newObj.value = 'Tom';
      console.log(obj,newObj)
    }
    return {newObj,change}
  }
}

上述代码,当change执行的时候,响应式数据发生改变,而原始数据obj并不会改变。

原因在于,ref的本质是拷贝,与原始数据没有引用关系

toRef

而如果使用toRef将某个对象中的属性变成响应式数据,修改响应式数据是会影响到原始数据的。但是需要注意,如果修改通过toRef创建的响应式数据,并不会触发UI界面的更新。

所以,toRef的本质是引用,与原始数据有关联

import {toRef} from 'vue';
export default {
  name:'App'
  setup(){
    let obj = {name : 'alice', age : 12};
    let newObj= toRef(obj, 'name');
    const change = () => {
      newObj.value = 'Tom';
      console.log(obj,newObj)
    }
    return {newObj,change}
  }
}

上述代码,当change执行的时候,响应式数据发生改变,原始数据obj并不会改变,但是UI界面不会更新

ref和toRef的区别

  • ref本质是拷贝,修改响应式数据不会影响原始数据;toRef的本质是引用关系,修改响应式数据会影响原始数据
  • ref数据发生改变,界面会自动更新;toRef当数据发生改变是,界面不会自动更新
  • toRef传参与ref不同;toRef接收两个参数,第一个参数是哪个对象,第二个参数是对象的哪个属性

所以如果想让响应式数据和以前的数据关联起来,并且想在更新响应式数据的时候不更新UI,那么就使用toRef

toRefs

有的时候,我们希望将对象的多个属性都变成响应式数据,并且要求响应式数据和原始数据关联,并且更新响应式数据的时候不更新界面,就可以使用toRefs,用于批量设置多个数据为响应式数据。(toRef一次仅能设置一个数据)
toRefs接收一个对象作为参数,它会遍历对象身上的所有属性,然后挨个调用toRef执行

import {toRefs} from 'vue';
export default {
  name:'App'
  setup(){
    let obj = {name : 'alice', age : 12};
    let newObj= toRefs(obj);
    const change = () => {
      newObj.name.value = 'Tom';
      newObj.age.value = 18;
      console.log(obj,newObj)
    }
    return {newObj,change}
  }
}

toRefs解决return变量过多的问题

在setup中定义的变量如果想要在HTML模板中使用,就需要将数据return出去。如果数据过多就需要在return中再写一遍这个数据。

import {toRefs} from 'vue';
export default {
  name:'App'
  setup(){
    let obj = reactive({
		dataList: [],
		isLoading: false,
		handleChange: ()=>{
			....
		}
	});
    return { ...toRefs(obj) }
  }
}

toref与torefs的区别

  • toref是将非响应式对象转换为ref对象,一次只转换一个
  • torefs是将响应式对象,转换成普通对象,普通对象的每一个property都是一个ref,返回包含这些ref对象的普通对象
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值