Vue3 中 reactive 对比 ref

文章对比了ref和reactive在定义、原理和使用角度的区别。ref适用于基本数据类型,而reactive用于对象或数组。ref通过Object.defineProperty实现响应式,reactive利用Proxy。在使用上,ref需要.value访问,而reactive则直接读写。
摘要由CSDN通过智能技术生成

目录

从定义角度对比

从原理角度对比

从使用角度对比


从定义角度对比

        1.ref 用来定义:基本数据类型

        2.reactive 用来定义:对象(或数组)类型数据

        3.备注:ref 也可以用来定义对象(或数组)类型的数据,它内部会调用通过 reactive 转为代理对象

从原理角度对比

        ref 通过 Object.defineProperty() 的 get 与 set 来实现响应式(数据劫持)

        reactive 通过使用 Proxy 来实现响应式(数据劫持),并通过 Reflect 操作源对象内部的数据,具体代码实现如下

             const p = new Proxy(person, {
            // 当有人读取 p 中的属性时调用
            get(target, propName) {
                console.log(`有人读取了p中的${propName}属性`)
                return Reflect.get(target, propName)
            },

            // 当有人修该 p 中的属性时调用,或有人给 p 中添加了属性调用
            set(target, propName, value) {
                console.log(`有人修改了p中的${propName}属性`)
                return Reflect.set(target, propName, value)
            },

            // 当有人删除了 p 中的属性
            deleteProperty(target, propName) {
                console.log(`有人删除了p中的${propName}属性`)
                return Reflect.deleteProperty(target, propName)
            }
        })

从使用角度对比

        ref 定义的数据:操作数据需要 .value,读取数据时模板中可以直接读取不需要  .value。

        reactive 定义的数据:操作数据与读取数据:均不需要  .value

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值