React Native中导航组件react-navigation跨tab路由处理详解


Posted in Javascript onOctober 31, 2017

前言

大家应该都有所体会,我们在一般应用都有跨tab跳转的需求, 这就需要特别处理下路由,所以 下面是使用react-navigation作为路由组件的一种方式.

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

方法如下:

首先选择路由结构, 选择使用最外层是StackNavigator, 然后包含3个TabNavigator和其他组件.

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账单首页了.

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
JQuery 遮罩层实现(mask)实现代码
Jan 09 Javascript
jQuery函数的等价原生函数代码示例
May 27 Javascript
非常好用的JsonToString 方法 简单实例
Jul 18 Javascript
$.get获取一个文件的内容示例代码
Sep 11 Javascript
js和php如何获取当前url的内容
Sep 22 Javascript
EasyUI实现第二层弹出框的方法
Mar 01 Javascript
javascript数据结构与算法之检索算法
Apr 04 Javascript
js中less常用的方法小结
Aug 09 Javascript
基于jQuery实现图片推拉门动画效果的两种方法
Aug 26 jQuery
AngularJs ng-change事件/指令的用法小结
Nov 01 Javascript
Vue异步组件处理路由组件加载状态的解决方案
Sep 07 Javascript
JavaScript 中 JSON.parse 函数 和 JSON.stringify 函数
Dec 05 Javascript
ES6解构赋值实例详解
Oct 31 #Javascript
js 获取json数组里面数组的长度实例
Oct 31 #Javascript
jQuery读取本地的json文件(实例讲解)
Oct 31 #jQuery
canvas绘制爱心的几种方法总结(推荐)
Oct 31 #Javascript
ES6扩展运算符用法实例分析
Oct 31 #Javascript
JavaScript中正则表达式使数字、中文或指定字符高亮显示
Oct 31 #Javascript
JavaScript实现QQ列表展开收缩扩展功能
Oct 30 #Javascript
You might like
php 文件夹删除、php清除缓存程序
2009/08/25 PHP
PHP使用range协议实现输出文件断点续传代码实例
2014/07/04 PHP
使用XHGui来测试PHP性能的教程
2015/07/03 PHP
php编程每天必学之表单验证
2016/03/01 PHP
PHP cookie,session的使用与用户自动登录功能实现方法分析
2019/06/05 PHP
PHP中有关长整数的一些操作教程
2019/09/11 PHP
JavaScript this 深入理解
2009/07/30 Javascript
jQuery的写法不同导致的兼容性问题的解决方法
2010/07/29 Javascript
JQuery动画animate的stop方法使用详解
2014/05/09 Javascript
jQuery中Ajax的load方法详解
2015/01/14 Javascript
JavaScript动态修改背景颜色的方法
2015/04/16 Javascript
Vuex2.0+Vue2.0构建备忘录应用实践
2016/11/30 Javascript
JS实现简单的选择题测评系统代码思路详解(demo)
2017/09/03 Javascript
使用mock.js随机数据和使用express输出json接口的实现方法
2018/01/07 Javascript
Vue源码解析之Template转化为AST的实现方法
2018/12/14 Javascript
js实现通过开始结束控制的计时器
2019/02/25 Javascript
一行JavaScript代码如何实现瀑布流布局
2020/12/11 Javascript
Python实现加载及解析properties配置文件的方法
2018/03/29 Python
Python爬虫爬取煎蛋网图片代码实例
2019/12/16 Python
Pytorch 实现冻结指定卷积层的参数
2020/01/06 Python
从python读取sql的实例方法
2020/07/21 Python
Python 如何定义匿名或内联函数
2020/08/01 Python
深入浅出CSS3 background-clip,background-origin和border-image教程
2011/01/27 HTML / CSS
Kathmandu美国网站:新西兰户外运动品牌
2019/03/23 全球购物
英国户外服装、鞋类和设备的领先零售商:Millets
2020/10/12 全球购物
学生就业推荐信
2013/11/13 职场文书
产品质量承诺范本
2014/03/31 职场文书
《一个小村庄的故事》教学反思
2014/04/13 职场文书
《美丽的南沙群岛》教学反思
2014/04/27 职场文书
学生检讨书怎么写
2014/10/09 职场文书
单位租房协议书范本
2014/12/04 职场文书
2016年教育局“我们的节日——端午节”主题活动总结
2016/04/01 职场文书
六一儿童节致辞稿(3篇)
2019/07/11 职场文书
互联网创业商业模式以及赚钱法则有哪些?
2019/10/12 职场文书
nginx常用配置conf的示例代码详解
2022/03/21 Servers
解决vue中provide inject的响应式监听
2022/04/19 Vue.js