vue3使用reactive包裹数组如何正确赋值

需求:将接口请求到的列表数据赋值给响应数据arr

  1. const arr = reactive([]);
    
    
    const load = () => {
    
    const res = [2, 3, 4, 5]; //假设请求接口返回的数据
    
    // 方法1 失败,直接赋值丢失了响应性
    
    // arr = res;
    
    // 方法2 这样也是失败
    
    // arr.concat(res);
    
    // 方法3 可以,但是很麻烦
    
    res.forEach(e => {
    
    arr.push(e);
    
    });
    
    };

vue3使用proxy,对于对象和数组都不能直接整个赋值。
使用方法1能理解,直接赋值给用reactive包裹的对象也不能这么做。

方法2为什么不行?
只有push或者根据索引遍历赋值才可以保留reactive数组的响应性?
如何方便的将整个数组拼接到响应式数据上?

提供几种办法

const state = reactive({

arr: []

});


state.arr = [1, 2, 3]
或者
const state = ref([])


state.value = [1, 2, 3]

或者

const arr = reactive([])


arr.push(...[1, 2, 3])

这几种办法都可以触发响应性,推荐第一种

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值