之前我们学习了可触摸组件和页面导航的使用的使用:

从零学React Native之09可触摸组件



从零学React Native之03页面导航

经过之前的学习, 我们可以完成一个自定义导航栏了, 效果如下:

我们需要创建一个 NaviBar.js 用来显示顶部的导航栏, 还需要四个界面(Page1.js,Page2.js,Page3.js,Page4.js)。 当然还需要修改index.android.js或者index.ios.js 用来处理4个界面的切换。

导航栏NaviBar 实现

这里, 我们就假设应用有4个栏目, 每个按钮的宽高比为 4:3

直接贴代码了:

import React, { Component } from 'react';
import {
AppRegistry,
StyleSheet,
View,
Text,
TouchableHighlight,
} from 'react-native'; var Dimensions = require("Dimensions");
var totalWidth = Dimensions.get('window').width;// 屏幕宽度
let naviButtonWidth = totalWidth / 4; //计算导航条每个宽度
let naviButtonHeight = naviButtonWidth * 0.75; // 导航条每个高度
export default class NaviBar extends Component {
// 构造
constructor(props) {
super(props);
this._tab0Pressed = this._tab0Pressed.bind(this);
this._tab1Pressed = this._tab1Pressed.bind(this);
this._tab2Pressed = this._tab2Pressed.bind(this);
this._tab3Pressed = this._tab3Pressed.bind(this);
} //四个按钮 被按下时处理函数
_tab0Pressed() {
this.props.onNaviBarPress(0);
} _tab1Pressed() {
this.props.onNaviBarPress(1);
} _tab2Pressed() {
this.props.onNaviBarPress(2);
} _tab3Pressed() {
this.props.onNaviBarPress(3);
} render() {
//通过属性得知哪个导航按钮是当前导航页, 这个导航用灰色背景
//利用JavaScript数组的map函数,从一个数组对应生成另一个数组buttonColors
// 看不懂该函数的,看下面的解释
var buttonColors = this.props.naviBarStatus.map(function (aNumber) {
if (aNumber == 0) return 'white';
return 'gray';
});
return (
//根View
<View style={styles.naviRow}>
<TouchableHighlight onPress={this._tab0Pressed}>
<View style={[styles.button,{backgroundColor:buttonColors[0]}]}>
<Text style={styles.textStyle1}>
条目一
</Text>
</View>
</TouchableHighlight>
<TouchableHighlight onPress={this._tab1Pressed}>
<View style={[styles.button,{backgroundColor:buttonColors[1]}]}>
<Text style={styles.textStyle1}>
条目二
</Text>
</View>
</TouchableHighlight>
<TouchableHighlight onPress={this._tab2Pressed}>
<View style={[styles.button,{backgroundColor:buttonColors[2]}]}>
<Text style={styles.textStyle1}>
条目三
</Text>
</View>
</TouchableHighlight>
<TouchableHighlight onPress={this._tab3Pressed}>
<View style={[styles.button,{backgroundColor:buttonColors[3]}]}>
<Text style={styles.textStyle1}>
条目四
</Text>
</View>
</TouchableHighlight>
</View>
);
}
}
// 声明属性, 方便使用当前组件
NaviBar.propTypes = {
naviBarStatus: React.PropTypes.arrayOf(React.PropTypes.number).isRequired,
onNaviBarPress: React.PropTypes.func.isRequired
}; //样式
const styles = StyleSheet.create({
naviRow: {
flexDirection: 'row'
},
button: {
width: naviButtonWidth,
height: naviButtonHeight,
justifyContent: 'center'
},
textStyle1: {
fontSize: 20,
textAlign: 'center'
}
});

上面用到了, Map函数 ,

Map函数的作用是按照某种关系从原数组”映射”出新数组. 如下面求平方的例子:

var data= [1,2,3,4];
var newArray=data.map((item)=>{return item*item});
console.log(newArray); //输出[1,4,9,16]

统一处理四个界面的切换

我们需要在index.android.js 或者index.ios.js 这个代码比较简单, 只需要导入四个界面, 用Navigator组件切换就可以了。

import React, { Component } from 'react';
import {
AppRegistry,
StyleSheet,
Navigator
} from 'react-native'; import Page1 from './Page1';
import Page2 from './Page2';
import Page3 from './Page3';
import Page4 from './Page4';
class AwesomeProject extends Component {
//告知Navigator 模块切换时的效果
configureScene() {
return Navigator.SceneConfigs.FadeAndroid;
}
//根据传递的信息, 处理界面的切换
renderScene(router, navigator) {
this._navigator = navigator;
switch (router.name) {
case 'Page1':
return <Page1 navigator={navigator}/>;
case 'Page2':
return <Page2 navigator={navigator}/>;
case 'Page3':
return <Page3 navigator={navigator}/>;
case 'Page4':
return <Page4 navigator={navigator}/>;
}
}
render() {
return (
//根View
<Navigator
initialRoute={{name:'Page1'}}
configureScene={this.configureScene}
renderScene={this.renderScene}/>
);
}
}
AppRegistry.registerComponent('AwesomeProject', () => AwesomeProject);

界面

上面的代码需要引入Page1 - Page4, 这个四个界面非常相似, 我们只贴其中一个了.

Page1.js

import React, { Component } from 'react';
import {
View,
StyleSheet,
} from 'react-native';
import NaviBar from './NaviBar'; export default class Page1 extends Component {
// 构造
constructor(props) {
super(props);
// 初始状态
this.onNaviBarPress = this.onNaviBarPress.bind(this);
} render() {
// 不同的Page,需要修改下面的这个数组, 通过数组控制导航栏条目显示状态
var naviStatus = [1, 0, 0, 0];
return (
<View style={styles.container}>
<NaviBar naviBarStatus={naviStatus}
onNaviBarPress={this.onNaviBarPress}/>
<View style={styles.whatLeft}/>
</View>
);
}
//不同的page需要修改返回值
onNaviBarPress(aNumber) {
switch (aNumber) {
case 0:
return;
case 1:
//通过replace切换
this.props.navigator.replace({
name: 'Page2'
});
return;
case 2:
this.props.navigator.replace({
name: 'Page3'
});
return;
case 3:
this.props.navigator.replace({
name: 'Page4'
});
return;
}
}
}
const styles = StyleSheet.create({
container: {
flex: 1
},
whatLeft: { // 组件定义了一个上边框
flex: 1,
borderTopWidth: 1,
borderColor: 'black',
backgroundColor:'red' //每个界面背景颜色不一样
}
});

顺便指出两点: 当根View没有指定背景色时, 默认值是一种灰色; 当子View没有指定背景色时,会继承父View的背景色。

更多精彩请关注微信公众账号likeDev,公众账号名称:爱上Android。

React Native自定义导航栏的更多相关文章

  1. [RN] React Native 自定义导航栏随滚动渐变

    React Native 自定义导航栏随滚动渐变 实现效果预览: 代码实现: 1.定义导航栏 NavPage.js import React, {Component} from 'react'; im ...

  2. React Native自定义导航条

    Navigator和NavigatorIOS 在开发中,需要实现多个界面的切换,这时候就需要一个导航控制器来进行各种效果的切换.在React Native中RN为我们提供了两个组件:Navigator ...

  3. React Native 之导航栏

    一定要参考官网: https://reactnavigation.org/docs/en/getting-started.html 代码来自慕课网:https://www.imooc.com/cour ...

  4. React Native 底部导航栏

    首先安装:npm install react-native-tab-navigator   然后再引入文件中    import TabNavigator from 'react-native-tab ...

  5. Taro多端自定义导航栏Navbar+Tabbar实例

    运用Taro实现多端导航栏/tabbar实例 (H5 + 小程序 + React Native) 最近一直在捣鼓taro开发,虽说官网介绍支持编译到多端,但是网上大多数实例都是H5.小程序,很少有支持 ...

  6. 分别用ToolBar和自定义导航栏实现沉浸式状态栏

    一.ToolBar 1.在build.gradle中添加依赖,例如: compile 'com.android.support:appcompat-v7:23.4.0' 2.去掉应用的ActionBa ...

  7. swift 自定义导航栏颜色

    func setNavigationApperance(){ //自定义导航栏颜色 [self.navigationController?.navigationBar.barTintColor = U ...

  8. ios7以上自定义导航栏标题的字体大小及颜色的方法

    自定义导航栏的字体和颜色,只需要自定义一个lable,然后将lable添加到导航栏的titleview中就可以了 代码如下 UILabel *label = [[UILabel alloc] init ...

  9. iOS 自定义导航栏笔记

    一.UINavigationBar的结构 导航栏几乎是每个页面都会碰到的问题,一般两种处理方式:1.隐藏掉不显示 2.自定义 1. 添加导航栏 TestViewController * mainVC ...

随机推荐

  1. 阿里云应用高可用服务 AHAS 流控降级实现 SQL 自动防护功能

    在影响系统稳定性的各种因素中,慢 SQL 是相对比较致命的,可能会导致 CPU.LOAD 异常.系统资源耗尽.线上生产环境出现慢 SQL 往往有很多原因: 硬件问题.如网络速度慢,内存不足,I/O 吞 ...

  2. 基于MaxCompute打造轻盈的人人车移动端数据平台

    摘要: 2019年1月18日,由阿里巴巴MaxCompute开发者社区和阿里云栖社区联合主办的“阿里云栖开发者沙龙大数据技术专场”走近北京联合大学,本次技术沙龙上,人人车大数据平台负责人吴水永从人人车 ...

  3. loj2322 「清华集训 2017」Hello world!

    https://loj.ac/problem/2322 先吐槽一下,sb数据毁我青春败我前程. 首先,一个数开根开不了多少次. 当我们把它开到1的时候,我们以后就不需要开他了,我们可以利用并查集跳过他 ...

  4. TZ_13_Hystix的熔断器

    1.作用:当服务繁忙时,如果服务出现异常,不是粗暴的直接报错,而是返回一个友好的提示,虽然拒绝了用户的访问,但是会返回一个结果. 熔断器的三种状态: Closed:关闭状态(断路器关闭),所有请求都正 ...

  5. Eclipse安装FindBugs

    Eclipse安装FindBugs 1.使用Eclipse的help在线安装,安装地址” FindBugs - http://findbugs.cs.umd.edu/eclipse-daily“. 2 ...

  6. iOS 动画队列—仿映客刷礼物效果

    http://www.cocoachina.com/ios/20160719/17101.html 最近在研究直播的相关知识,在网上看到了不少优秀的开源项目,但都没有看到映客那个刷礼物的效果,于是手痒 ...

  7. jquery Select2 学习笔记之中文提示 - CSDN博客

    首先学习这个东西呢,还是看官网比较全面 select2官网例子 要select2中文显示:必须要引入中文包,且一定要放在select2.js之后 [javascript] view plain cop ...

  8. ACdream 1101 线段树

    题目链接 瑶瑶想要玩滑梯 Time Limit: 10000/5000MS (Java/Others)Memory Limit: 512000/256000KB (Java/Others) Submi ...

  9. 痞子衡嵌入式:飞思卡尔i.MX RTyyyy系列MCU外设那些事(2)- 善变的FlexRAM

    大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是飞思卡尔i.MX RTyyyy系列MCU的FlexRAM外设. 本文是外设系列第二篇,上一篇讲的是离内核最近的高速缓存L1 Cache, ...

  10. FPGA按键功能

    1.如何判断按键成功按下? 2.在什么时候采集数据? 按键在按下的过程中会产生大约2ms-3ms抖动,如果此时此刻采集数据来判断按键是不准确的,那么为了采集到准确的数据需要设置一个大约10ms左右的计 ...