我在react-native中使用TabNavigator和StackNavigator时遇到了问题。当我按下一个按钮时,我想重置我的导航。我在我的标签导航中有我的堆栈导航。问题是我只能重置一个导航...
计划:
-tabNavigator
-listing.js
-stackNavigator
-types.js
-picture.js
-ad.js因此,当我在ad.js中,当我点击它的时候,我会有一个按钮,我的stackNavigation重置为type.js,Listing.js上的tabNavigator,所以我想最终返回Linsting.js。
我的导航: navigation.js
export const resetAction = NavigationActions.reset({
index: 0,
actions: [
NavigationActions.navigate({ routeName: 'Types'}),
],
key: null
})
export const listingAction = NavigationActions.navigate({
routeName: 'Listing',
})
const Stack = StackNavigator(
{
Types: {screen: SelectTypesScreen},
Picture: {screen: SelectPictureScreen},
Ad: {screen: CreateAd}
})
const Tab = TabNavigator(
{
Listing: {screen: ListingScreen},
Preference: {screen: PreferencesScreen},
Add: {screen : Stack}
},
{
}
)
export default class App extends Component {
render() {
return (
<Tab />
);
}
}选项卡导航linsting.js
export default class Listing extends Component {
render() {
return (
<View>
<Text> Listing </Text>
</View>
);
}
}堆栈导航ad.js
export default class CreateAd extends Component {
render() {
return (
<View>
<Text style={{marginTop: '80%', marginLeft: '40%'}}> Ad </Text>
<Button title="Ok" onPress={() => {console.log("displayer 1"), this.props.navigation.dispatch(resetAction), console.log("displayer 2"), this.props.navigation.dispatch(listingAction)}} />
</View>
);
}
}发布于 2017-11-11 02:44:28
最好是更改Navigations的嵌套结构。最好按照文档的确切方式去做。根导航器可以是堆栈导航器,您可以将tabnavigator作为屏幕添加到其中
const MainScreenNavigator = TabNavigator({
Recent: { screen: RecentChatsScreen },
All: { screen: AllContactsScreen },
});
const SimpleApp = StackNavigator({
Home: { screen: MainScreenNavigator },
Chat: { screen: ChatScreen },
});https://stackoverflow.com/questions/47226116
复制相似问题