【报错】Can’t perform a React state update on an unmounted component. This is a no-op, but it indica

报错

Can’t perform a React state update on an unmounted component. This is a no-op, but it indicates a memory leak in your application. To fix, cancel all subscriptions and asynchronous tasks in a useEffect cleanup function.

分析

这是由于请求接口数据加载比较慢,setState还未完成,用户切换了组件或者切换页面时候,此时组件已被卸载,仍然尝试修改组件的状态所导致的问题。在组件被卸载后,setState动作还在持续,但此时无法使用setState来改变组件的状态,这会导致React引擎出现内存泄漏警告。

解决

为了解决这个问题,应该在组件卸载时,清除所有的异步任务和订阅,可以使用useEffect的清理函数来完成这个任务。在清理函数中取消所有正在进行的异步任务。

函数式组件写法

useEffect(() => {
  const fetchData = async () => {
    const result = await axios.get('api/data')
    setData(result.data)
  }
  fetchData()
  return () => {
    // 在组件卸载后取消异步任务
    if (source) {
      source.cancel('Component unmounted')
    }
  }
}, [])

类组件写法

componentWillUnmount() {
   this.setState = () => false
}
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

田本初

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

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

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

打赏作者

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

抵扣说明:

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

余额充值