useEffect 清理/内存泄漏

问题描述

我编写了一个 ReactJS Web 应用程序。这是一个单页应用程序 (SPA)。 我有一个包含多个页面菜单。每个页面都是一个 .js 文件。 由于 SPA,当我在菜单中更改页面时,我的浏览器无法刷新整个页面

这是我放在每一页上的内容

const myPageLoad = useCallback(async () => {
   // loading data
},[]);

useEffect(() => {
  myPageLoad();
},[myPageLoad]); 

“加载数据”可能需要 3-4 秒才能加载数据。 它工作正常。

如果我决定在“加载数据”完成之前从菜单中更改页面,我会在 javascript 控制台中收到此警告:

Warning: 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. in Data (created by Context.Consumer)

如果我检测到页面更改,我想我必须取消我的加载特性。但我该怎么做?

非常感谢

解决方法

您可以使用 abort,我通过这种方式修复此类错误:

useEffect(() => {
  // get abortion variables
  let abortController = new AbortController();
  let aborted = abortController.signal.aborted; // true || false
  async function fetchResults() {
    let response = await fetch(`[WEBSITE LINK]`);
    let data = await response.json();
    aborted = abortController.signal.aborted; // before 'if' statement check again if aborted
    if (aborted === false) {
      // Make sure all your 'set states' inside this kind of 'if' statement
      setState(data);
    }
  }
  fetchResults();
  // make sure to return this abort()
  return () => {
    abortController.abort();
  };
},[])

其他方法:https://medium.com/wesionary-team/how-to-fix-memory-leak-issue-in-react-js-using-hook-a5ecbf9becf8