The simplest stack navigator for react native applications which has no bloatware unlike other alternates. Works with React Native vanilla as well as expo. No native code involved. React 16.8.x+
NPM: https://www.npmjs.com/package/rn-stack-navigator
To install simply type:
npm i rn-stack-navigator --save
or
yarn add rn-stack-navigator
Usage You get 3 Components and 1 hook from rn-stack-navigator
import { NavContainer, Nav, NavScreen, useNavigator } from 'rn-stack-navigator';
Use NavContainer component as the root of your App.
All your Screens lie inside Nav component. Nav component as an optional props: defaultScreen, where you can pass the name of the screen which you want to appear first, if not passed it will use the first NavScreen component's name.
NavScreen component takes 2 props: name, where you name your component, and component, where you pass your actual component. Also NavScreen component takes any other props you pass and sends it to the respective screen as props.
And useNavigator gives 2 functions, setScreen, clearHistoryAndSetScreen. setScreen takes the name of the screen and navigates to that screen, clearHistoryAndSetScreen takes the name of the screen, clears the previous screen history and sets the new screen.
Example:
App.js
import React from 'react';
import { StyleSheet, View } from 'react-native';
import Screen1 from './screens/Screen1';
import Screen2 from './screens/Screen2';
import Screen3 from './screens/Screen3';
import Screen4 from './screens/Screen4';
import { NavContainer, Nav, NavScreen } from 'rn-stack-navigator';
export default function App() {
return (
<NavContainer>
<View style={styles.container}>
<Nav defaultScreen="screen3">
<NavScreen name="screen1" component={Screen1} />
<NavScreen
name="screen2"
component={Screen2}
propPassingExample={{ arr: [1, 2, 3] }}
/>
<NavScreen name="screen3" component={Screen3} />
<NavScreen name="screen4" component={Screen4} />
</Nav>
</View>
</NavContainer>
);
}
const styles = StyleSheet.create({
container: {
flex: 1,
alignItems: 'center',
justifyContent: 'center',
},
});
Screen1.js
import React from 'react';
import { View } from 'react-native';
import CustomText from '../CustomText';
import { useNavigator } from 'rn-stack-navigator';
export default () => {
const { setScreen, clearHistoryAndSetScreen } = useNavigator();
return (
<View style={{ backgroundColor: 'yellow' }}>
<CustomText text="Screen1" onPress={() => setScreen('screen1')} />
<CustomText
text="Screen2"
style={{ color: 'blue' }}
onPress={() => setScreen('screen2')}
/>
<CustomText
text="Screen3"
style={{ color: 'blue' }}
onPress={() => setScreen('screen3')}
/>
<CustomText
text="Screen4"
style={{ color: 'blue' }}
onPress={() => {
clearHistoryAndSetScreen('screen4');
}}
/>
</View>
);
};