有没有办法让菜单从左到右而不是从右到左呈现?从导航栏的右键单击时,就可以了;而不是从左侧按钮,它呈现在屏幕外。
问问题
588 次
2 回答
1
这是一个简短的示例,如何使用带有反应导航的弹出菜单。菜单在headerRight
和headerLeft
占位符中呈现。两边都正确显示:
import React from 'react';
import { AppRegistry, Text } from 'react-native';
import { StackNavigator } from 'react-navigation';
import Menu, {
MenuContext,
MenuOptions,
MenuOption,
MenuTrigger
} from 'react-native-popup-menu';
const NavigatorMenu = ({ navigation }) => (
<Menu>
<MenuTrigger text='...' />
<MenuOptions>
<MenuOption
onSelect={() => navigation.navigate('Page2')}
text='Navigate Page 2'
/>
<MenuOption
onSelect={() => navigation.navigate('Page3')}
text='Navigate Page 3'
/>
</MenuOptions>
</Menu>
);
class Home extends React.Component {
static navigationOptions = ({ navigation }) => ({
title: 'Home',
headerRight: <NavigatorMenu navigation={navigation} />,
headerLeft: <NavigatorMenu navigation={navigation} />,
});
render() {
return <Text>Home Page</Text>;
}
}
const Page2 = () => <Text>2nd Page</Text>;
const Page3 = () => <Text>3rd Page</Text>;
const TopStackNavigator = StackNavigator({
Home: { screen: Home },
Page2: { screen: Page2 },
Page3: { screen: Page3 },
});
const App = () => (
<MenuContext>
<TopStackNavigator />
</MenuContext>
);
AppRegistry.registerComponent('examples', () => App);
它在android上进行了测试:
- 反应原生:0.37.0
- 反应原生弹出菜单:0.7.3
- 反应导航:1.0.0-beta
于 2017-05-11T09:05:59.533 回答
0
解决了。在测试期间,我混合了 react-native-menu 和 react-native-popup-menu。我都安装了。Webstorm 把我拉进了两个库的导入中,将它们混合在一起。
于 2017-05-11T11:18:35.263 回答