[openDrawer()来自子导航器的屏幕

问题描述 投票:0回答:1

我有以下反应本机代码:

import React from 'react';
import {AppRegistry} from 'react-native';
import { createAppContainer } from 'react-navigation';
import { createStackNavigator} from 'react-navigation-stack';
import { createDrawerNavigator} from 'react-navigation-drawer';
import {View,Text,Button} from 'react-native';

class Sub extends React.Component {
  static navigationOptions = {
    headerTitle: () => (
      <Button
        onPress={() => this.props.navigation.dangerouslyGetParent().openDrawer()}
        title="Open Drawer"
      />
    ),
  };
  render() {
      const props = this.props;
      return (
        <View>
        <Text>{props.navigation.state.routeName}</Text>
        <Button onPress={_=>props.navigation.navigate("Sub1")} title="Sub1" />
        <Button onPress={_=>props.navigation.navigate("Sub2")} title="Sub2" />
        </View>
      );
  }
}

const SubRoutes = {
    "Sub1":Sub
};

const SubNavigator = createStackNavigator(SubRoutes);

const SubApp = createAppContainer(SubNavigator);

const MainRoutes = {
    "Main1":SubApp
};

const MainNavigator = createDrawerNavigator(MainRoutes);

const App = createAppContainer(MainNavigator);

AppRegistry.registerComponent("nav", () => App);

它将StackNavigator呈现为DrawerNavigator的子代。在Sub屏幕中,我有一个带按钮的headerTitle,当单击时,我想打开抽屉式导航器的抽屉菜单。现在,单击按钮只会显示Sub.props.navigation不存在的错误。

单击标题标题按钮时如何打开抽屉菜单?

react-native react-navigation
1个回答
1
投票

请为此修改您的navigationOptions代码:

  ...
  static navigationOptions = ({navigation}) => ({
    headerTitle: () => (
      <Button
        onPress={() => navigation.openDrawer()}
        title="Open Drawer"
      />
    )
  });
  ...
© www.soinside.com 2019 - 2024. All rights reserved.