eltree ref什么时候有_图文讲解vue3中ref和reactive的区别

大家都知道vue3在9月18号晚上发布了,在vue3中对响应式数据的声明官方给出了ref()和reactive()这两种方式,今天我们来聊聊两种定义定义数据方式有什么不同

c090edae372058a571fcc3dd17c41b6b.png

如上代码,我们使用变量声明的方式,ref的方式,reactive的方式定义的三个变量,num1,num2,num3

a06e4bbedb41e75a1a0aff72f4fd18dd.png

我们发现使用ref定义的数据,打印结果是一个被对象包裹的响应的数据,使用reactive的方式和纯变量声明的方式打印结果是一样的,这是什么原因呢?

我们发现在控制台输出一个警告信息, 提示100这个值不能被reactive创建,官方也推荐我们在定义数据的时候,reactive定义复杂的数据类型的数据,ref推荐定义基本数据类型,所以如果要使用reactive定义基本数据类型的话,我们需要在reactive中将数据包装一下

3dfbcdfb6ad754bd61b5e2a08f5d945f.png
64197cbddcd4359791bd7e860fce8733.png

我们在使用reactive定义数据的时候用对象做一层包裹,这样控制台就不会报警告信息了,

但是使用reactive定义的数据和ref定义的数据打印结果有一些差异

f4731fc0f67d30578946c31344ef7e66.png
cb539d6db2af2ccff72ed06aad769284.png

我们发现ref定义的数据打印结果需要.value才能获取到结果,而reactive则不需要

5225e7b627f8947c1cf543e0632553fd.png

总结:

reactive 和 ref 都是用来定义响应式数据的 reactive更推荐去定义复杂的数据类型 ref 更推荐定义基本类型

ref 和 reactive 本质我们可以简单的理解为ref是对reactive的二次包装, ref定义的数据访问的时候要多一个.value

使用ref定义基本数据类型,ref也可以定义数组和对象。

以上就是本期知识分享,记得关注黑马君哦,更多干货等你来学~

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值