避坑18_Vue祖孙组件通过provide/inject异步传值,孙组件拿不到数据

本文介绍了在Vue中,祖孙组件通过`provide/inject`进行异步传值时遇到的问题,即孙组件无法获取到父组件异步更新的数据。原因是`provide`和`inject`绑定不具备响应性,且异步调用发生在组件初始化之后。解决办法是将数据包裹在可监听的对象中,确保属性变化能够被追踪。
摘要由CSDN通过智能技术生成
一、问题

简化代码如下图所示:请添加图片描述

二、原因和解决方法
  • 因为在父组件异步获取数据前,tableData的空值就已传给了孙组件(详情查看父子组件生命周期执行顺序,其次异步调用在最后执行)
  • 在异步调用结束后,又因为provide 和 inject 绑定并不是可响应的。这是刻意为之的。然而,如果你传入了一个可监听的对象,那么其对象的属性还是可响应的。

说人话就是如果你把对象都改了那这个改动就追踪不到了,如果你就改了个对象属性那这种响应就能追踪到。以下是具体的代码分析。

解决思路: 将实际想获取的数组包裹在对象中作为对象的属性传递,也就是tableData.list,将整个tableData传过去,tableData.list的改变可以被响应。

// parent.vue
data () {
   
    tabl
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值