React Native 无法从 > 不同组件的函数体内部更新组件

ReactNative Cannot update a component from inside the function body of a > different component

我的HomeHeader组件是这样的:

import React from "react";
import { View, StyleSheet, Text, Image } from "react-native";
import Icon from "react-native-vector-icons/FontAwesome5";

export default function HomeHeader({ navigation }) {
  return (
    <View style={styles.home_header}>
      <Icon
        style={styles.menu}
        name="bars"
        size={30}
        color="white"
        onPress={navigation.toggleDrawer()}
      />

      <Image
        style={styles.header_logo}
        source={require("../assets/logo.png")}
      />
      <Text>Hello</Text>
    </View>
  );
}

我在我的主页屏幕上使用它,如下所示:

return (
  <View>
    <HomeHeader navigation={navigation} />
  </View>
)

但我收到此错误消息:

Warning: Cannot update a component from inside the function body of a different component.

我想做的是,我将主屏幕的页眉部分分离到一个名为 HomeHeader 的单独组件中。在这个组件中,我附加了事件处理程序来切换 DrawerNavigation(左侧抽屉菜单)opening/closing

如果我在主屏幕中创建一个按钮并添加事件处理程序来切换抽屉,它就可以正常工作。但是只有当我在我的 HomeHeader 组件中尝试这个时才会出现这个问题。

顺便说一句,我正在使用 ReactNavigation v5,我什至尝试过这种方法:https://reactnavigation.org/docs/connecting-navigation-prop/

到目前为止运气不好。

onPress={ navigation.toggleDrawer() }更改为 onPress={ ()=> navigation.toggleDrawer() }

您可以在 here

中阅读更多相关信息