解决react项目结合Ant-Design的Tabs组件时,tab切换不刷新导致数据不同步更新的问题

本文介绍了在React项目中使用Ant Design的Tabs组件时遇到的tab切换不刷新问题,导致数据不同步更新。通过监听Tabs的onChange回调,并在子组件中利用componentDidUpdate生命周期方法,对比props来实现数据的正确刷新。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

场景介绍

两个tab,一个已接受,一个已拒绝,在已接受中可以进行拒绝操作,拒绝后在已拒绝tab中会展示刚刚拒绝的那条数据。问题:拒绝后点击展示已拒绝tab,发现并没有更新

 <Tabs defaultActiveKey={currentKey} onChange={this.onTabChange}>
          {
            tabs.map((item) => (
              <Tabs.TabPane tab={item.title} key={item.key}>
                <item.component type={type} />
              </Tabs.TabPane>
            ))
          }
        </Tabs>

解决

使用Tabs的onChange回调,
在这里插入图片描述
使用该回调,

 onTabChange = (tabKey) => {
    this.setState({
      type:tabKey
    })
  }

然后在子组件中使用 componentDidUpdate生命周期函数
componentDidUpdate的第一个参数为 preProps 表示上一次的props
componentDidUpdate参数详解

componentDidUpdate(preProps ){
   if(preProps.type!==this.props.type){
      //放置刷新函数
   }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值