react-native的tabbar和navigator混合使用
前段时间搭建项目使用了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混合使用的更多相关文章
- React Native学习之自定义Navigator
Navigator还是最常用的组件, 所以自己封装了一个, 使用起来也比较简单, 如下: 首先导入组件 var MLNavigator = require('../Lib/MLNavigator'); ...
- React Native导航器Navigator
React Native导航器Navigator 使用导航器可以让你在应用的不同场景(页面)间进行切换.导航器通过路由对象来分辨不同的场景.利用renderScene方法,导航栏可以根据指定的路由来渲 ...
- React Native专题
转载注明出处:地址:http://www.lcode.org本文出自:[江清清的技术专栏]本React Native讲解专题:主要讲解了React Native开发,由基础环境搭建配置入门,基础,进阶 ...
- React Native专题-江清清
本React Native讲解专题:主要讲解了React Native开发,由基础环境搭建配置入门,基础,进阶相关讲解. 刚创建的React Native交流8群:533435865 欢迎各位大牛, ...
- React Native 常用插件案例
(二).基础入门: 1.React Native For Android环境配置以及第一个实例 2.React Native开发IDE安装及配置 3.React Native应用设备运行(Runnin ...
- React Native组件(二)View组件解析
相关文章 React Native探索系列 React Native组件系列 前言 了解了RN的组件的生命周期后,我们接着来学习RN的具体的组件.View组件是最基本的组件,也是首先要掌握的组件,这一 ...
- React Native常用组件之TabBarIOS、TabBarIOS.Item组件、Navigator组件、NavigatorIOS组件、React Navigation第三方
以下内容为老版本React Native,faceBook已经有了新的导航组件,请移步其他博客参考>>[我是传送门] 参考资料:React Navigation react-native ...
- React Native之 Navigator与NavigatorIOS使用
前言 学习本系列内容需要具备一定 HTML 开发基础,没有基础的朋友可以先转至 HTML快速入门(一) 学习 本人接触 React Native 时间并不是特别长,所以对其中的内容和性质了解可能会有所 ...
- [转] 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 ...
随机推荐
- Java 8 的 Nashorn 脚本引擎教程
本文为了解所有关于 Nashorn JavaScript 引擎易于理解的代码例子. Nashorn JavaScript 引擎是Java SE 8的一部分,它与其它像Google V8 (它是Goog ...
- webpack+react+redux+es6开发模式
一.预备知识 node, npm, react, redux, es6, webpack 二.学习资源 ECMAScript 6入门 React和Redux的连接react-redux Redux 入 ...
- Mysql存储引擎及选择方法
0x00 Mysql数据库常用存储引擎 Mysql数据库是一款开源的数据库,支持多种存储引擎的选择,比如目前最常用的存储引擎有:MyISAM,InnoDB,Memory等. MyISAM存储引擎 My ...
- [原] KVM 虚拟化原理探究(2)— QEMU启动过程
KVM 虚拟化原理探究- QEMU启动过程 标签(空格分隔): KVM [TOC] 虚拟机启动过程 第一步,获取到kvm句柄 kvmfd = open("/dev/kvm", O_ ...
- 简历生成平台项目开发-STEP1问卷设计
周五课程结束完后,小组建立QQ群和微信群,着手讨论项目问题.一开始的大概想法:就业信息平台,收集企业招聘信息和就业生资料,提供给学生和企业的校企对接平台.后来发现群里谭卓同学也有个相关的思路,经过商量 ...
- Ubuntu下配置apache开启https
一.HTTPS简述随着网络的日常,信息安全越来越重要,传统的网站都是http协议明文传输,而HTTPS协议是由SSL+HTTP协议构建的可进行加密传输.身份认证的网络协议,比http协议安全. 那ht ...
- CentOS:Yum源的配置
# cd /etc/yum.repos.d/ # mv CentOS-Base.repo CentOS-Base.repo.bak # wget http://mirrors.163.com/.hel ...
- 瞬间记住Javascript中apply与call的区别
关于Javascript函数的apply与call方法的用法,网上的文章很多,我就不多话了.apply和call的作用很相似,但使用方式有区别 apply与call的第一个参数都是一个对象,这个对象就 ...
- C#与C++的发展历程第一 - 由C#3.0起
俗话说学以致用,本系列的出发点就在于总结C#和C++的一些新特性,并给出实例说明这些新特性的使用场景.前几篇文章将以C#的新特性为纲领,并同时介绍C++中相似的功能的新特性,最后一篇文章将总结之前几篇 ...
- Markdown是怎样接管我的各种的写作工作的
对于一个程序猿来说,没有什么比单纯的写代码更能让人兴奋了.如果能让你像写代码一样写文档,不用再面对那些繁琐的样式,你会怎么看?它就是Markdown!即使博客园已经有不少介绍的文章了,但是我依然还是不 ...