为了账号安全,请及时绑定邮箱和手机立即绑定

无法对未安装的组件主题提供程序执行 React 状态更新

无法对未安装的组件主题提供程序执行 React 状态更新

肥皂起泡泡 2022-01-01 20:53:15
我需要帮助,因为我收到以下错误:警告:无法对未安装的组件执行 React 状态更新。这是一个空操作,但它表明您的应用程序中存在内存泄漏。要修复,请取消 componentWillUnmount 方法中的所有订阅和异步任务。在 createCategory 中(在 themeProvider.js:39)/* Imports */    import React, { useContext, useState, useEffect } from 'react';    import AsyncStorage from '@react-native-community/async-storage';    import THEMES from '@app/theme/themes.json';    /* /Imports/ */    const STORAGE_KEY = 'THEME_ID';    const ThemeContext = React.createContext();    /* Exports */    export const ThemeContextProvider = ({ children }) => {      const [themeID, setThemeID] = useState();      useEffect(() => {        (async () => {          const storedThemeID = await AsyncStorage.getItem(STORAGE_KEY);          if (storedThemeID) setThemeID(storedThemeID);          else setThemeID(THEMES[1].key);        })();      }, []);      return (        <ThemeContext.Provider value={{ themeID, setThemeID }}>          {!!themeID ? children : null}        </ThemeContext.Provider>      );    };    export function withTheme(Component) {      function TargetComponent(props) {        const { themeID, setThemeID } = useContext(ThemeContext);        const getTheme = themeID => THEMES.find(theme => theme.key === themeID);        const setTheme = themeID => {          AsyncStorage.setItem(STORAGE_KEY, themeID);          setThemeID(themeID);        };        return (          <Component            {...props}            themes={THEMES}            theme={getTheme(themeID)}            setTheme={setTheme}          />        );      }      TargetComponent.navigationOptions = Component.navigationOptions;      return TargetComponent;      }    /* /Exports/ */
查看完整描述

2 回答

?
元芳怎么了

TA贡献1798条经验 获得超7个赞

如果您还不知道 - 您可以在 useEffect 钩子的末尾返回一个函数。每当该效果再次触发时(例如,当其依赖项的值发生变化时),以及在组件卸载之前,都会调用该函数。所以如果你有一个像这样的 useEffect 钩子:


useEffect(() => {

  // logic here


  return () => {

    // clean up

  };

}, []); // no dependencies!

相当于:


class SomeComponent extends React.Component {

  componentDidMount() {

    // logic here

  }


  componentWillUnmount() {

    // clean up

  }

}

所以在你的代码中我会添加这个:


useEffect(() => {

  let isCancelled = false;

  const fetchData = async () => {

    try {

      // fetch logic omitted...

      const data = await AsyncStorage.getItem(STORAGE_KEY);


      if (storedThemeID) setThemeID(storedThemeID);

      else setThemeID(THEMES[1].key);

    } catch (e) {

      throw new Error(e)

    }

  };


  fetchData();


  return () => {

    isCancelled = true;

  };

}, [themeID]);


查看完整回答
反对 回复 2022-01-01
?
慕村225694

TA贡献1880条经验 获得超4个赞

试试这个


let unmounted = false;


useEffect(() => {

    (async () => {

        const storedThemeID = await AsyncStorage.getItem(STORAGE_KEY);

        if (!unmounted) {

            if (storedThemeID) setThemeID(storedThemeID);

            else setThemeID(THEMES[1].key);

        }

    })();

    return () => {

        unmounted = true;

    };

}, []);


查看完整回答
反对 回复 2022-01-01
  • 2 回答
  • 0 关注
  • 250 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号