如何使用react-navigation从标题中的按钮“导航”到新屏幕?

时间:2017-03-30 08:36:11

标签: javascript reactjs react-navigation

我正在使用react-navigation并希望在我的标题右侧添加一个按钮,该按钮将导航到其他屏幕。但是在设置navigationOptions时,我想知道如何在按下按钮时调用的回调中访问navigate函数:

const RootNavigationStack = StackNavigator({
  PokemonList: {
    screen: PokemonListWrapper,
    navigationOptions: {
      title: ({state}) => `Pokedex`,
      header: ({ state, setParams }) => {
        return {
          visible: true,
          right: (
            <Button
              title={'Add'}
              onPress={() => // navigate to new screen here
            />
          ),
        }
      }
    },
  },
, {
  headerMode: 'screen'
})

有关如何实现这一目标的任何想法?我在考虑使用withNavigation,但我还不太清楚它是如何工作的。

3 个答案:

答案 0 :(得分:5)

我使用此问题解决了同样的问题(在屏幕/组件类内部)

static navigationOptions = ({navigation}) => {
  return {
    title: 'Next',
    headerRight: <Button
                     title="Next"

                     onPress={ () => navigation.navigate('RegPasswordScreen')} />

  };
};

答案 1 :(得分:4)

另一个答案适用于旧版本的React Navigation。

对于新版本,请尝试以下操作:

static navigationOptions = ({ navigation }) => ({
        headerRight: (
            <Button 
                title='Setting' 
                onPress={ () => navigation.navigate('RouteName') }                
                backgroundColor= "rgba(0,0,0,0)"
                color="rgba(0,122,255,1)"
            />
        )});

答案 2 :(得分:2)

试试这个。

    header: ({ navigate }) => ({
       right: (
          <Button onPress={() => navigate('screen2')}  />
       )
    }),