前段时间搭建项目使用了navigator和react-native-tab-navigator,现在我教大家搭建一个通用的简单框架。

先把几张图贴在这里,这就是我们今天要搭建的东西,别看页面简单,但是可塑性强啊(我才不会说我已经懒到一定程度了呢...)!

1.     2.            3.

上面的三张图就是咱们要搭建的简单框架。

大家都知道,一般一个app都有导航、tabbar以及tabbaritem的子页面。那么上面的第一张就是导航初始化的页面,图2是tabbar的页面,图3就是tabbaritem的子页面。

废话不多说,直接干活!

一、初始化路由

在react-native里面路由就是navigator,关于navigator做过移动端开发的童鞋应该都不陌生。iOS里面叫UINavigationController,Android里面应该叫Action Bar吧。

对于一个app我们一般只用一个路由。所以在程序启动的时候我们要初始化路由。

我习惯把路由初始化放在一个单独的文件中,下面放上代码

 import React, { Component } from 'react';
import {
AppRegistry,
Navigator,
Platform,
} from 'react-native'; import LogIn from './login'; const defaultRoute = {
component: LogIn,
}; export default class NavIndex extends Component {
_renderScene(route, navigator) {
let Component = route.component;
return (
<Component {...route.params} navigator={navigator} />
);
}
render() {
return (
<Navigator
initialRoute={defaultRoute}
renderScene={this._renderScene} />
);
}
}

当然我们注册应用入口的时候直接注册navigator这个模块就可以了,我这里写的navigator其实是非常简单的,这也就是把路由初始化在上面第一个页面,一般除了引导页,那么程序第一个页面就是登陆页面,登陆页面看上面就知道我写的比较简单,代码就不粘贴了,点击登陆实现方法

_onPage(){
this.props.navigator.push({
component:TabbarView,
})
}

跳转到图二,也就是Tabbar页面,当然,登陆页面不一定非得跳到tabbar页面,这里只是一个简单的框架代码,有对Navigator想要深入了解的童鞋,可以看官网文档,或者可以看这里江清清的技术专栏,里面都有详细介绍。

二、Tabbar的使用

关于tabbar,这里我用了react-native-tab-navigator,这理我介绍一下怎么使用,首先需要install:  npm install react-native-tab-navigator --save

然后import就可以引用了,这是github上的一个开源框架,我感觉还挺好用的。

现在我们来搭建tabbar。

constructor(props) {
super(props);
this.state = {selectedTab: '通知'}
} render() {
return (
<View style={styles.container}>
<TabNavigator hidesTabTouch={true} tabBarStyle={styles.tab}>
<TabNavigator.Item
selected={this.state.selectedTab === '通知'}
title='通知'
renderIcon={() => <Image style={styles.tabIcon} />}
renderSelectedIcon={() => <Image style={styles.tabIcon} />}
onPress={() => this.setState({ selectedTab: '通知' })}>
       
        //MeView是tabbaritem的页面
<MeView navigator={this.props.navigator}/>

</TabNavigator.Item> </TabNavigator>
</View>
);
}
}

这就是这个框架的简单使用,其中renderIcon和renderSelectedIcon是点击和nomal显示的图片,styles.tabIcon可以自定义图片的属性。

有的童鞋在使用tabbar的时候,push不到下一个页面,那么看这一句,<MeView navigator={this.props.navigator}/>,加上navigator={this.props.navigator},MeView就能跳转到它的子页面了。这一句话是必不可少的,在MeView中Push的话,MeView的子页面中tabbar会消失,因为MeView的子页面是一个全新的页面。它没有继承Tabbar,但是如果单独给MeView添加navigator的话,MeView的子页面就继承了Tabbar,这也就是一个给tabbar加导航还是给页面加导航的问题。

写到这,基本上这个简单的框架也就完成的差不多了。

三、tabbarItem子页面

到这里已经接近尾声,那么来看一下图三。图三的文字我也加了一个点击方法

_onBack(){
this.props.navigator.pop()
}

一看就明白,push,pop,这个是返回的方法,点几一下试试,你肯定会发现,tabbar在主页面又出现了!

最后怎么能不放上源代码呢?

代码放在github上了:https://github.com/Demon404/react-native-navtab

react-native的tabbar和navigator混合使用的更多相关文章

  1. React Native学习之自定义Navigator

    Navigator还是最常用的组件, 所以自己封装了一个, 使用起来也比较简单, 如下: 首先导入组件 var MLNavigator = require('../Lib/MLNavigator'); ...

  2. React Native导航器Navigator

    React Native导航器Navigator 使用导航器可以让你在应用的不同场景(页面)间进行切换.导航器通过路由对象来分辨不同的场景.利用renderScene方法,导航栏可以根据指定的路由来渲 ...

  3. React Native专题

    转载注明出处:地址:http://www.lcode.org本文出自:[江清清的技术专栏]本React Native讲解专题:主要讲解了React Native开发,由基础环境搭建配置入门,基础,进阶 ...

  4. React Native专题-江清清

    本React Native讲解专题:主要讲解了React Native开发,由基础环境搭建配置入门,基础,进阶相关讲解. 刚创建的React Native交流8群:533435865  欢迎各位大牛, ...

  5. React Native 常用插件案例

    (二).基础入门: 1.React Native For Android环境配置以及第一个实例 2.React Native开发IDE安装及配置 3.React Native应用设备运行(Runnin ...

  6. React Native组件(二)View组件解析

    相关文章 React Native探索系列 React Native组件系列 前言 了解了RN的组件的生命周期后,我们接着来学习RN的具体的组件.View组件是最基本的组件,也是首先要掌握的组件,这一 ...

  7. React Native常用组件之TabBarIOS、TabBarIOS.Item组件、Navigator组件、NavigatorIOS组件、React Navigation第三方

    以下内容为老版本React Native,faceBook已经有了新的导航组件,请移步其他博客参考>>[我是传送门] 参考资料:React Navigation  react-native ...

  8. React Native之 Navigator与NavigatorIOS使用

    前言 学习本系列内容需要具备一定 HTML 开发基础,没有基础的朋友可以先转至 HTML快速入门(一) 学习 本人接触 React Native 时间并不是特别长,所以对其中的内容和性质了解可能会有所 ...

  9. [转] React Native Navigator — Navigating Like A Pro in React Native

    There is a lot you can do with the React Native Navigator. Here, I will try to go over a few example ...

随机推荐

  1. CSS 3学习——边框

    在CSS 3中可以设置边框圆角.边框阴影和边框图像,分别通过border-radius.border-image和box-shadow属性设置. 边框圆角 border-radius属性是以下4个属性 ...

  2. Hibernate中事务声明

    Hibernate中JDBC事务声明,在Hibernate配置文件中加入如下代码,不做声明Hibernate默认就是JDBC事务. 一个JDBC 不能跨越多个数据库. Hibernate中JTA事务声 ...

  3. PHP设计模式(六)原型模式(Prototype For PHP)

    原型设计模式: 用原型实例指定创建对象的种类,并且通过拷贝这些原型创建新的对象. 原型设计模式简单的来说,顾名思义, 不去创建新的对象进而保留原型的一种设计模式. 缺点:原型设计模式是的最主要的缺点就 ...

  4. Flexible 弹性盒子模型之CSS flex-grow 属性

    实例 让第二个元素的宽度为其他元素的三倍: div:nth-of-type(1){flex-grow:1;} div:nth-of-type(2){flex-grow:3;} div:nth-of-t ...

  5. Android—应用程序开机自启

    android开机时候会发送开机广播,我们想要收到广播知道手机开机,才能启动我们的应用程序. 首先要在配置文件中添加相应权限: <uses-permission android:name=&qu ...

  6. Android Weekly Notes Issue #236

    Android Weekly Issue #236 December 18th, 2016 Android Weekly Issue #236 本期内容包括: Google的物联网平台Android ...

  7. 【番外篇】ASP.NET MVC快速入门之免费jQuery控件库(MVC5+EF6)

    目录 [第一篇]ASP.NET MVC快速入门之数据库操作(MVC5+EF6) [第二篇]ASP.NET MVC快速入门之数据注解(MVC5+EF6) [第三篇]ASP.NET MVC快速入门之安全策 ...

  8. Xamarin.Android-捕获未处理异常(全局异常)

    一.前言 android中如果出现了未处理的异常,程序会闪退,这是非常不好的用户体验,很多用户会因此卸载APP,因此未处理的异常是应该尽力避免的. 有些很难避免的异常(如:IO.网络等),应在代码中进 ...

  9. 吐血大奉献,打造cnblogs最新最火辣的css3模板(IE9以下请勿入内) -- 第一版

    一直自己都想给自己的博客打造一个独一无二的皮肤,但是一直没有强劲的动力去完成这件事情.后来凭借着工作上面的需求(涉及到css3),就把自己的博客当成一个最好的试验场地.从而产生了你现在所看到的这个模板 ...

  10. Web API 入门指南 - 闲话安全

    Web API入门指南有些朋友回复问了些安全方面的问题,安全方面可以写的东西实在太多了,这里尽量围绕着Web API的安全性来展开,介绍一些安全的基本概念,常见安全隐患.相关的防御技巧以及Web AP ...