首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >TabNavigator重置

TabNavigator重置
EN

Stack Overflow用户
提问于 2017-11-10 23:26:14
回答 1查看 580关注 0票数 0

我在react-native中使用TabNavigator和StackNavigator时遇到了问题。当我按下一个按钮时,我想重置我的导航。我在我的标签导航中有我的堆栈导航。问题是我只能重置一个导航...

计划:

代码语言:javascript
复制
-tabNavigator
   -listing.js
   -stackNavigator
      -types.js
      -picture.js
      -ad.js

因此,当我在ad.js中,当我点击它的时候,我会有一个按钮,我的stackNavigation重置为type.js,Listing.js上的tabNavigator,所以我想最终返回Linsting.js。

我的导航: navigation.js

代码语言:javascript
复制
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

代码语言:javascript
复制
export default class Listing extends Component {
    render() {
        return (
            <View>
                <Text> Listing </Text>
            </View>
        );
    }
}

堆栈导航ad.js

代码语言:javascript
复制
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>
        );
    }
}
EN

回答 1

Stack Overflow用户

发布于 2017-11-11 02:44:28

最好是更改Navigations的嵌套结构。最好按照文档的确切方式去做。根导航器可以是堆栈导航器,您可以将tabnavigator作为屏幕添加到其中

代码语言:javascript
复制
const MainScreenNavigator = TabNavigator({
  Recent: { screen: RecentChatsScreen },
  All: { screen: AllContactsScreen },
});

const SimpleApp = StackNavigator({
  Home: { screen: MainScreenNavigator },
  Chat: { screen: ChatScreen },
});

参考文档https://reactnavigation.org/docs/intro/nesting

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/47226116

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档