为什么“ this.props.navigation”不可用于屏幕组件?

时间:2019-10-21 22:33:55

标签: react-native react-navigation

我有一个抽屉式导航器,其中有一个嵌套在其中的堆栈导航器,作为屏幕选项之一。导航到抽屉中的任何屏幕都没有问题,但是当我尝试导航到堆栈导航器中的另一个屏幕时,我无权访问this.props.navigation。我很困惑,因为屏幕是在我的导航器设置中声明的。

AppNavigator:

// all imports

const InboxStack = createStackNavigator(
  {
    Inbox: {
      screen: HomeScreen
    },
    Conversation: {
      screen: ConversationScreen
    }
  },
  {
    headerMode: "none",
    initialRouteName: "Inbox"
  }
);

const MainNavigator = createDrawerNavigator(
  {
    Inbox: InboxStack,
    Second: { screen: SecondScreen },
    Third: { screen: ThirdScreen }
  },
  {
    drawerPosition: "left",
    initialRouteName: "Inbox",
    navigationOptions: ({ navigation }) => ({
      title: "Drawer Navigator Header",
      headerTitleStyle: {
        color: "blue"
      },
      headerLeft: <Text onPress={() => navigation.toggleDrawer()}>Menu</Text>
    })
  }
);

const WrapperStackNavigator = createStackNavigator({
  drawerNav: MainNavigator
});

const AppContainer = createAppContainer(
  createSwitchNavigator(
    {
      AuthLoading: AuthLoadingScreen,
      App: WrapperStackNavigator,
      Login: LoginScreen,
      Register: RegisterScreen
    },
    {
      initialRouteName: "AuthLoading"
    }
  )
);

export default AppContainer;

在ConversationScreen中使用导航道具:

import React from "react";
import { View, Text } from "react-native";
import { connect } from "react-redux";
import { loadConversation } from "../actions";
import MessagesList from "../components/MessagesList.js";

class ConversationScreen extends React.Component {
  constructor(props) {
    super(props);
  }
  componentDidMount() {
    this.loadConversation();
  }

  loadConversation() {
    this.props.loadConversation(
      this.props.navigation.state.params.convoId // this works!
      this.props.navigation.getParams("convoId") // this does not :(
    );
  }

  render() {
    return (
      <View
        style={{
          display: "flex",
          alignItems: "center",
          justifyContent: "center"
        }}
      >
        <Text>Conversation screen</Text>
        <MessagesList messages={this.props.messages} />
      </View>
    );
  }
}
const mapStateToProps = ({ conversation, auth }) => {
  const { messages } = conversation;
  const { user } = auth;
  return { messages, user };
};
const mapDispatchToProps = {
  loadConversation
};
export default connect(
  mapStateToProps,
  mapDispatchToProps
)(ConversationScreen);

ConversationScreen存在问题,我无权访问导航道具,但是文档说,如果它在导航器中声明,则应将其传递给导航道具。每个使用this.props.navigation... is not a function的{​​{1}}错误的呼叫 ... is undefined...this.props.navigation.navigate

1 个答案:

答案 0 :(得分:0)

通过alert(this.props)检查了props对象之后,我证实我可以访问导航对象,即使它似乎是未定义的,最终还是使用

componentDidMount() {
   loadConversation() {
    this.props.loadConversation(
      this.props.navigation.state.params.convoId
    );
   }
 }

这把我带到了我需要去的地方。尽管只使用this.props.navigation.getParams()

会很好