【异常记录】React子组件通过componentDidMount()生命周期函数获取父组件props失败

前景说明:

React子组件通过componentDidMount()生命周期函数获取父组件中props失败

报错原因:

父组件在渲染时异步加载了数据,并将其通过 props 传递给子组件,那么在子组件 componentDidMount() 函数中访问这些 props 可能会发生延迟。因为在子组件挂载时,异步请求可能还没有完成,父组件传递的 props 还没有准备好。

解决办法:

 componentDidUpdate(prevProps, prevState) {
    if (prevProps.parentProp !== this.props.parentProp) {//这里的parentProp为父组件props中的参数名
      //方法调用 实现逻辑
    }
  }

使用 componentDidUpdate() 函数检查父组件传递的 props 是否发生了变化,这样可以确保在子组件挂载时,父组件传递的 props 已经准备好,并且可以及时更新子组件中的数据。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值