【Vue3】ref与reactive详解

Vue3中通过引入ref与relactive属性来实现数据的响应式
引入方式:import {ref,relactive} from 'vue'

ref

对于基本数据的响应式,我们要通过ref属性进行封装:
基本数据的响应式原理还是用object.defineProperty通过给每个属性添加getter和setter对数据进行劫持处理。

let name = ref('张三');
let age = ref(18);

在JS内想要获取修改定义的数据时需要通过×××.value进行获取,例如:

function getData(){
	name.value='李四';
	age.value=20;
}

在模板内则可以直接填写属性,例如:

<h1>姓名{{name}}</h1>
<h1>年龄{{age}}</h1>

reactive

对于对象等引用数据的响应式我们需要用relactive进行封装,如果用ref进行封装,则Vue会自动将ref转化成relactive:
在Vue3中对引用数据类型的响应式处理是通过es6的proxy与reflect,(用reflect可以避免重复使用try catch)进行判断对数据进行拦截处理。relactive定义的响应式是深层次的

//对象的响应式
let job = reactive({
	type:'前端工程师',
	salary:'10k'
});
//数组的响应式
let hobby = reactive(['抽烟','喝酒','烫头']);
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

打代码能当饭吃?

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值