In my React Native app I have the following TabNavigator
nested inside an AppNavigator
:
const TabNavigator = () => (
<Tab.Navigator>
<Tab.Screen component={Screen1} />
</Tab.Navigator>
);
export const AppNavigator = () => {
const [loading, setLoading] = useState(false);
<Stack.Navigator>
<Stack.Screen component={TabNavigator}/>
<Stack.Screen component={OtherComponent1}/>
<Stack.Screen component={OtherComponent2}/>
</Stack.Navigator>
}
I want to pass the loading
hook to Screen1
.
What I've tried:
- Putting
const TabNavigator
etc insideAppNavigator
. The problem with this is,AppNavigator
re-renders a lot, and thereforeScreen1
re-renders and flickers a lot. - Passing
loading
as a prop toTabNavigator
andScreen1
, like<Stack.Screen component={() => <TabNavigator loading={loading}/>}/>
and<Tab.Screen component={() => <Screen1 loading={props.loading}/>} />
. The problem with this is is that it gives me this warning about passing an inline function.
What's the best way to approach this?
You can use the Context API to pass the value. https://reactjs.org/docs/context.html