本文基于React Native 0.52

Demo上传到Git了,有需要可以看看,写了新内容会上传的。Git地址 https://github.com/gingerJY/React-Native-Demo

一、基础

1、三种类型

    • TabNavigator —— 用于设置多个选项卡的页面
    • StackNavigator —— 用于页面之间的跳转
    • DrawerNavigator —— 用于侧面滑出的抽屉效果

  2、属性配置

    • navigate(routeName, params, action) —— 跳转页面

      • routeName:目标路由名称
      • params:传递参数(目标页面用this.props.navigation.state.params可以取出参数)
      • action:在子页面运行的操作(没用过,有需要可以参看官方文档)
    • state —— 当前页面的状态
      • 例如,传递的params就存在state中
    • setParams —— 设置路由参数
    • goBack —— 关闭当前页面,返回上一页
      • 也可以设置返回到指定页(如:a-->b-->c-->d,如果goBack(),则d返回到c;如果goBack(b),则d返回到a)
    • dispatch —— 发送一个动作到路由(没用过,有需要可以参看官方文档)

二、实例(完整代码在4)

安装react-navigation

npm install react-navigation --save

  1、TabNavigator

  ① 添加几个简单的页面(如下图中的home、user、category,都是一样的,就改下名字)  

import React, { Component } from 'react';
import {
StyleSheet,
View,
Text,
} from 'react-native'; export default class home extends Component { render() {
return (
<View style={styles.container}>
<Text>home</Text>
</View>
);
}
}
const styles = StyleSheet.create({
container: {
flex: ,
alignItems: 'center',
backgroundColor: '#ff9999',
},
});

②App.js

    • 引入需要跳转的页面;根据需要引入三种导航

      import {DrawerNavigator,StackNavigator, TabNavigator, TabBarBottom } from 'react-navigation';
      import Home from './app/page/home/home';
      ……………………省略
    • 设置切换的页面及其label、icon;设置tabBar位置、动画,状态样式等
      const Tab = TabNavigator(
      {
      Home: {
      screen: Home,
      navigationOptions: ({ navigation }) => ({
      tabBarLabel: '首页',
      tabBarIcon: ({ tintColor }) => (
      <Image source={require('./app/img/home.png')} style={[{ tintColor: tintColor, width: , height: }]} />
      ),
      })
      },
      ………………省略
      },
      {
      tabBarComponent: TabBarBottom,
      tabBarPosition: 'bottom',//tabBar位置
      // swipeEnabled: false,//是否滑动切换,默认true
      animationEnabled: true,
      lazy: true,
      tabBarOptions: {
      activeTintColor: '#ff4f39',
      inactiveTintColor: '#979797',
      style: { backgroundColor: '#ffffff' },
      },
      }
      );

2、StackNavigator

①在App.js中加入如下代码。把tab包含到这里面,search就是需要跳转的页面。

const Stack = StackNavigator(
{
Tab: { screen: Tab },
Search: { screen: Search },
}, {
navigationOptions: {
headerBackTitle: null,
headerTintColor: '#333333',
showIcon: true,
gesturesEnabled: true,
header: null,
},
mode: 'card',
headerMode: 'screen',
}
);

    ②在home.js添加一个按钮,点击跳转Search页面

<Button
onPress={() => {this.props.navigation.navigate('Search')}}
title="go to Search"
/>

3、DrawerNavigator

    ① 在App.js加入DrawerNavigator ,把StackNavigator包在里面(现在从外到里的顺序是DrawerNavigator,StackNavigator, TabNavigator)

const Drawer = DrawerNavigator(
{
Stack: { screen: Stack },
Search: { screen: Search },
},
);

    ②在home.js添加一个按钮,点击打开侧边栏

<Button
onPress={() => {this.props.navigation.navigate('DrawerToggle')}}
title="Drawer"
/>

  4、完整代码

    App.js完整代码https://github.com/gingerJY/example/blob/master/RN_navigation/App.js

    home.js完整代码 https://github.com/gingerJY/example/blob/master/RN_navigation/home.js

三、效果图

  图一是TabNavigator 实现的底部导航

  图二是StackNavigator 实现跳转search页面

  图三是DrawerNavigator 实现抽屉导航

         

参考文档https://reactnavigation.org/docs/navigators/navigation-prop

END----------------------------------------------------------------------------------------

React Native学习(三)—— 使用导航器Navigation跳转页面的更多相关文章

  1. React Native 学习(三)之 FlexBox 布局

    React Native 学习(三)之 FlexBox 布局

  2. React Native学习(二)—— 开始一个项目

    本文基于React Native 0.52 一.创建一个项目 1.初始化一个RN项目 react-native init RNDemo 2.连接一个设备或是打开模拟器 可以通过 adb devices ...

  3. React Native 学习笔记--进阶(二)--动画

    React Native 进阶(二)–动画 动画 流畅.有意义的动画对于移动应用用户体验来说是非常必要的.我们可以联合使用两个互补的系统:用于全局的布局动画LayoutAnimation,和用于创建更 ...

  4. iOS 写给iOS开发者的React Native学习路线(转)

    我是一名iOS开发者,断断续续一年前开始接触React Native,最近由于工作需要,专职学习React Native也有一个多月了.网络上知识资源非常的多,但能让人豁然开朗.迅速学习的还是少数,我 ...

  5. 写给iOS开发者的React Native学习路线(转)

    我是一名iOS开发者,断断续续一年前开始接触React Native,最近由于工作需要,专职学习React Native也有一个多月了.网络上知识资源非常的多,但能让人豁然开朗.迅速学习的还是少数,我 ...

  6. React Native 学习-01

    React Native 学习 (学习版本 0.39) 一.环境配置 二.IDE选择 webstorm 1.webstorm配置 ①.首先是可以选择使用汉化包汉化.eu68 ②.安装插件和外部库. 由 ...

  7. react native 学习一(环境搭配和常见错误的解决)

    react native 学习一(环境搭配) 首页,按照http://reactnative.cn/docs/0.30/getting-started.html#content上的介绍,下载安装pyt ...

  8. React Native 学习资料

    React Native 学习资料 学习资料 网址 React Native中文网 https://reactnative.cn/

  9. ios学习-delegate、传值、跳转页面

    ios学习-delegate.传值.跳转页面     1.打开xcode,然后选择ios--Application--Empty Application一个空项目. 项目目录: 2.输入项目名称以及选 ...

随机推荐

  1. ansible编译httpd playbook示例

    以下是playbook的内容.它的处理流程是: 1.先在本地下载apr,apr-util,httpd共3个.tar.gz文件. 2.解压这3个文件. 3.安装pcre和pcre-devel依赖包. 4 ...

  2. SDWebimage如何获取缓存大小以及清除缓存

    sdwebimage如何获取缓存大小以及清除缓存 1.找到SDImageCache类 2.添加如下方法: - (float)checkTmpSize {    float totalSize = 0; ...

  3. 查看系统分区df,查看、设置、修改、删除ACL权限

    df [root@localhost ~]# df -h 文件系统 容量 已用 可用 已用% 挂载点 /dev/sda5 16G 1.4G 15G 9% / devtmpfs 479M 0 479M ...

  4. less基础语法

    变量 //->LESS代码 @link-color: #428bca; @link-color-hover: darken(@link-color, 10%); a { color: @link ...

  5. Memcached的简介和使用

    缘起: 在数据驱动的web开发中,经常要重复从数据库中取出相同的数据,这种重复极大的增加了数据库负载.缓存是解决这个问题的好办法.但是ASP.NET中的虽然已经可以实现对页面局部进行缓存,但还是不够灵 ...

  6. css:background-position > 精灵技术

    background-position : length || length background-position : position || position 取值: length  : 百分数 ...

  7. Spring+MVC+Mybatis整合

    本文是对慕课网上"搞定SSM开发"路径的系列课程的总结,详细的项目文档和课程总结放在github上了.点击查看 什么是秒杀业务 网站售卖某产品时,规定在某个日期开始售卖限量的产品, ...

  8. Kotlin——最详细的常量、变量、注释的使用

    在Kotlin中的变量.常量以及注释多多少少和Java语言是有着不同之处的.不管是变量.常量的定义方式,还是注释的使用.下面详细的介绍Kotlin中的变量.常量.注释的使用.以及和Java的对比. 如 ...

  9. 程序员的自我救赎---11.4:FileSystem文件服务

    <前言> (一) Winner2.0 框架基础分析 (二)PLSQL报表系统 (三)SSO单点登录 (四) 短信中心与消息中心 (五)钱包系统 (六)GPU支付中心 (七)权限系统 (八) ...

  10. C# 命名空间和程序集

    一.命名空间 1.通过使用using关键字引入命名空间,减少代码量 命名空间对相关的类型进行逻辑分组,通过命名空间能快速的定位到相关的类型,例如:在System.IO命名空间下,定义了所有I/O操作的 ...