ref、reactive、toRef、toRefs的区别

ref、reactive、toRef、toRefs的区别

vue3.0里给数据添加响应式有很多api可用。
文章内容转载
https://blog.csdn.net/u010059669/article/details/112287552

reactive

reactive 用于为对象添加响应式状态。接收一个js对象作为参数,返回一个具有响应式状态的副本。

  • 获取数据值的时候直接获取,不需要加.value
  • 参数只能传入对象类型
const {ref,reactive,toRefs}=Vue  //从Vue封装中导入
    const app = Vue.createApp({
        template: `
            <div>    
                <h2>type:--->{{job.type}}</h2>  
                <h2>salary:-->{{job.salary}}</h2> 
            </div>
        `,
        
        setup(props) {
            let job = reactive({type:'UI',salary:20}) 
            setTimeout(() => {
                job.type='come on',
                job.salary=666
                
                console.log(job)
            }, 2000);
            return {job}
        }
    })
    const vm = app.mount("#app")

ref

ref 用于为数据添加响应式状态。由于reactive只能传入对象类型的参数,而对于基本数据类型要添加响应式状态就只能用ref了,同样返回一个具有响应式状态的副本。

  • 获取数据值的时候需要加.value。(对于基本数据类型,ref是自己的实现方式且性能优于reactive,而对于对象类型,ref仍然是通过reactive包装实现的)
  • 参数可以传递任意数据类型,传递对象类型时也能保持深度响应式,所以适用性更广。
  • vue 3.0 setup里定义数据时推荐优先使用ref,方便逻辑拆分和业务解耦。
const {ref}=Vue  //从Vue封装中导入
    const app = Vue.createApp({
        template: `
            <div>
                <h1>我的信息</h1>
                <h2>姓名:{{name}}</h2>
                <h2>年龄:{{age}}</h2>
                <h2>type:{{job.type}}</h2>  
                <h2>salary:{{job.salary}}</h2> 
            </div>
        `,
        
        setup(props) {
            let name = ref('andy')
            let age = ref(22)
            let job = ref({  //proxy代理对象
                type:'UI设计师',
                salary:20
            })
            
            setTimeout(() => {
                job.value.type='come on',
                job.value.salary=666
                
                console.log(job)
            }, 2000);
            return {name,age,job}
        }
    })

toRef

toRef 用于为源响应式对象上的属性新建一个ref,从而保持对其源对象属性的响应式连接。接收两个参数:源响应式对象和属性名,返回一个ref数据。例如使用父组件传递的props数据时,要引用props的某个属性且要保持响应式连接时就很有用。

  • 获取数据值的时候需要加.value
  • toRef后的ref数据不是原始数据的拷贝,而是引用,改变结果数据的值也会同时改变原始数据

toRefs

toRefs 用于将响应式对象转换为结果对象,其中结果对象的每个属性都是指向原始对象相应属性的ref。常用于es6的解构赋值操作,因为在对一个响应式对象直接解构时解构后的数据将不再有响应式,而使用toRefs可以方便解决这一问题。

  • 获取数据值的时候需要加.value
  • toRefs后的ref数据不是原始数据的拷贝,而是引用,改变结果数据的值也会同时改变原始数据
  • 作用其实和 toRef 类似,只不过 toRef 是一个个手动赋值,而 toRefs 是自动赋值。
const {reactive,toRefs}=Vue  //从Vue封装中导入
    const app = Vue.createApp({
        template: `
            <div>
                <h1>我的信息</h1>
                <h2>type:{{job.type}}--->{{type}}</h2>  
                <h2>salary:{{job.salary}}-->{{salary}}</h2> 
            </div>
        `,
        
        setup(props) {
            let job = reactive({type:'UI',salary:20}) 
            let{type,salary} = toRefs(job)//可直接通过属性访问,不需要从对象名字中引用
            setTimeout(() => {
                job.type='come on'  //toRefs写法
                job.salary=666
                console.log(job)
            }, 2000);
            return {job,type,salary}
        }
    })

结语

尽量不要混着用,reactive和ref选一种,toRef和toRefs选一种,不然代码会很乱,推荐ref和toRefs一把梭。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值