Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Welcome To Ask or Share your Answers For Others

Categories

0 votes
1.1k views
in Technique[技术] by (71.8m points)

drop down menu - How to set options of the header in react-navigation (class component)?

I am having trouble with adding an element in header of Home page. I can currently add a button but thats in function home_customers_bar which is just a function that returns several screens. I want the element to be set in one of those screens which in my case is home_customers.js. In home_customers.js I am fetching some data that I would like to add to that element that I want to add in the header (dropdown menu).

I have my navigation container in a separate file.

navigation.js below:

<NavigationContainer>
  <Stack.Navigator>
    <Stack.Screen name="home_customers" component={home_customers} options={{ headerShown: false }} />
    <Stack.Screen name="home_customers_bar" component={home_customers_bar} />
  </Stack.Navigator>
</NavigationContainer>

then I have home_customers_bar where I return four screens, below I am only showing one for brevity

home_customers_bar.js file below:

import home_customers from './home_customers';

export default function home_customers_bar({ route, navigation }) {
const current_city_ = route.params.current_user_city_;
navigation.setOptions({
headerRight: () => (
<Button title="Update count" />
        ),
    });
return (
    <Tab.Navigator initialRouteName="Home" barStyle={{ backgroundColor: 'grey' }} screenOptions=
    {({ route, navigation }) => ({tabBarIcon: ({ focused, color, size }) => {
      if (route.name === 'Home') {
        return <Image style={{ width: 22, height: 22 }} source=    
         {require('../../../icons/home_icon.png')}></Image>;
      }
     },
    })} >
     <Tab.Screen name="Home" initialParams={{ current_city_: current_city_ }} component= home_customers} />
   </Tab.Navigator>
    );
}

As you see I am using setOptions in home_customers_bar and it displays the button properly but in my case, I would like to display a dropdown menu and populate it with dynamic data which I fetch in home_customers screen. So, I cant populate it while it is in home_customers_bar function.

question from:https://stackoverflow.com/questions/65872785/how-to-set-options-of-the-header-in-react-navigation-class-component

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome To Ask or Share your Answers For Others

1 Reply

0 votes
by (71.8m points)
Waitting for answers

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
OGeek|极客中国-欢迎来到极客的世界,一个免费开放的程序员编程交流平台!开放,进步,分享!让技术改变生活,让极客改变未来! Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Click Here to Ask a Question

...