最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

导航组件react-navigation如何使用

来源:动视网 责编:小采 时间:2020-11-27 20:08:16
文档

导航组件react-navigation如何使用

导航组件react-navigation如何使用:这次给大家带来的是导航组件react-navigation如何使用,大家应该都有所体会,我们在一般应用都有跨tab跳转的需求, 这就需要特别处理下路由,这篇文章就给大家好好分析一下。具体情境是: app分三大模块Home主页, Bill账单和Me我的, 对应三个tab. 现
推荐度:
导读导航组件react-navigation如何使用:这次给大家带来的是导航组件react-navigation如何使用,大家应该都有所体会,我们在一般应用都有跨tab跳转的需求, 这就需要特别处理下路由,这篇文章就给大家好好分析一下。具体情境是: app分三大模块Home主页, Bill账单和Me我的, 对应三个tab. 现


这次给大家带来的是导航组件react-navigation如何使用,大家应该都有所体会,我们在一般应用都有跨tab跳转的需求, 这就需要特别处理下路由,这篇文章就给大家好好分析一下。

具体情境是: app分三大模块Home主页, Bill账单和Me我的, 对应三个tab. 现在需求是 Home push HomeTwo, HomeTwo push BillTwo, BillTwo 返回到 Bill账单首页.

const Components = {
 HomeTwo: { screen: HomeTwo, path:'app/HomeTwo' },
 HomeThree: { screen: HomeThree, path:'app/HomeThree' },
 BillTwo: { screen: BillTwo, path:'app/BillTwo' },
 BillThree: { screen: BillThree, path:'app/BillThree' },
}
 
const Tabs = TabNavigator({
 Home: {
 screen: Home,
 path:'app/home',
 navigationOptions: { 
 tabBar: {
 label: '首页',
 icon: ({tintColor}) => (<Image source={require('./images/home.png')} style={[{tintColor: tintColor},styles.icon]}/>),
 },
 }
 },
 Bill: {
 screen: Bill,
 path:'app/bill',
 navigationOptions: {
 tabBar: {
 label: '账单',
 icon: ({tintColor}) => (<Image source={require('./images/bill.png')} style={[{tintColor: tintColor},styles.icon]}/>),
 },
 }
 },
 Me: {
 screen: Me,
 path:'app/me',
 navigationOptions: {
 tabBar: {
 label: '我',
 icon: ({tintColor}) => (<Image source={require('./images/me.png')} style={[{tintColor: tintColor},styles.icon]}/>),
 },
 }
 }
 }, {
 tabBarPosition: 'bottom', 
 swipeEnabled: false,
 animationEnabled: false, 
 lazyLoad: false, 
 backBehavior: 'none', 
 tabBarOptions: {
 activeTintColor: '#ff8500', 
 inactiveTintColor: '#999',
 showIcon: true, 
 indicatorStyle: {
 height: 0 
 },
 style: {
 backgroundColor: '#fff', 
 },
 labelStyle: {
 fontSize: 10, 
 },
 },
 });
 
 
 const Navs = StackNavigator({
 Home: { screen: Tabs, path:'app/Home' },
 Bill: { screen: Tabs, path:'app/Bill' },
 Me: { screen: Tabs, path:'app/Me' },
 ...Components
 }, {
 initialRouteName: 'Home', 
 navigationOptions: { 
 header: { 
 style: {
 backgroundColor: '#fff'
 },
 titleStyle: {
 color: 'green'
 }
 },
 cardStack: { 
 gesturesEnabled: true
 }
 },
 mode: 'card', 
 headerMode: 'screen'
 });

在HomeTwo里使用react-navigation自带的reset action就可以重置路由信息了:

// push BillTwo
this.props.navigation.dispatch(resetAction);
 
// 使用reset action重置路由
const resetAction = NavigationActions.reset({
 index: 1, // 注意不要越界
 actions: [ // 栈里的路由信息会从 Home->HomeTwo 变成了 Bill->BillTwo
 NavigationActions.navigate({ routeName: 'Bill'}),
 NavigationActions.navigate({ routeName: 'BillTwo'})
 ]
});

从HomeTwo push 到 BillTwo页面后, 点击BillTwo的左上角导航按钮返回就能返回到Bill账单首页了.

相信看了以上介绍你已经掌握了方法,更多精彩请关注Gxl网其它相关文章!

相关阅读:

驼峰命名与JS的问题解答

JS里的布尔值、关系运算符、逻辑运算符的详解及实例

js代码案列-根据日期计算星期几

文档

导航组件react-navigation如何使用

导航组件react-navigation如何使用:这次给大家带来的是导航组件react-navigation如何使用,大家应该都有所体会,我们在一般应用都有跨tab跳转的需求, 这就需要特别处理下路由,这篇文章就给大家好好分析一下。具体情境是: app分三大模块Home主页, Bill账单和Me我的, 对应三个tab. 现
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top