美文网首页
ReactNactive导航

ReactNactive导航

作者: 一只小丫丫 | 来源:发表于2020-04-23 17:48 被阅读0次

官网 : https://reactnavigation.org/docs/getting-started

安装 依赖

npm install @react-navigation/native
npm install @react-navigation/stack
npm install @react-navigation/bottom-tabs
npm install @react-navigation/material-top-tabs react-native-tab-view
//原生导航
//堆栈导航
//底部导航
//顶部安卓导航
npm install 
react-native-reanimated
react-native-gesture-handler 
react-native-screens 
react-native-safe-area-context @react-native-community/masked-view

配置

android/app/build.gradle dependencies 对象里面
implementation 'androidx.appcompat:appcompat:1.1.0-rc01'
implementation 'androidx.swiperefreshlayout:swiperefreshlayout:1.1.0-alpha02'

堆栈导航

  • 01 导入
import {NavigationContainer} from '@react-navigation/native';
//  导航容器
import {createStackNavigator} from '@react-navigation/stack';
//  导入创建堆栈导航方法
  • 02 创建 堆栈导航
    const Stack = createStackNavigator();
  • 03 创建导航需要的页面
  • 04 包装到导航
<NavigationContainer>
   <Stack.Navigator>
    <Stack.Screen 
    name="Home" 
    component={Home}
    />
    <Stack.Screen 
    name="Details" 
    component={Details}         
    />
  </Stack.Navigator>
</NavigationContainer>

//  NavigationContainer 导航容器
//  Stack.Navigator 堆栈导航
//  Stack.Screen  堆栈导航页面

页面的跳转

this.props.navigation

push                //推入堆栈
replace            //替换当前页面
goBack()          //返回
popToTop()       //回到顶层

参数的处理

  • 传递参数
    navigation.push(“Details”,{id:"abc"})
  • 获取参数
    this.props.route.params.id
  • 配置初始化参数
    <Stack.Screen initialParams={{id:1}}>
  • 堆栈导航参数
    title="详情",标题
    headerStyle:(backgroundColor:"#f30") 标题栏样式

底部导航

  • 01 导入
import { NavigationContainer } from '@react-navigation/native';
// 导入导航容器
import {createBottomTabNavigator} from '@react-navigation/bottom-tabs'
// 导入创建底部导航方法
  • 02 创建
    const Tab = createBottomTabNavigator();
  • 03 包装
<NavigationContainer />
  <Tab.Navigator />
    <Tab.Screen  name={} component={} />
  • 参数
    Screen.options
tabBarLabel //底部标签名
tabBarlcon:({focused})=>( )} //图标

Navigator.tabBarOptions
activeTintColor //选中的颜色

  • 切换
this.props.navigation.navigate("名称")
navigation.navigate(" Home")

顶部导航

使用步骤

import { createMaterialTopTabNavigator } from '@react-navigation/material-top-tabs';
// 导入创建顶部部导航方法
const TopTab = createMaterialTopTabNavigator();
// 01 导入并创建顶部导航
  • 包装
<TopTab.Navigator />
    <TopTab.Screen componet={} name="" />
  • 参数
    Navigator
    tabBarOptions
activeTintColor:"#f30",
//激活颜色
indicatorStyle:{backgroundColor:"#f30"},
//提示线条 css
inactiveTintColor:"#999",
//非激活颜色
tabStyle: { width: 150 },
//标签的样式
scrollEnabled:true,
//可以滚动

相关文章

  • ReactNactive导航

    官网 : https://reactnavigation.org/docs/getting-started 安装 ...

  • ios原生项目展示reactnavtive界面(RN学习二)

    基础:ios工程集成好reactnactive(可参考https://www.jianshu.com/p/2336...

  • 前段常用单词

    一、导航类 导航:nav 主导航:mainbav 子导航:subnav 顶导航:topnav 边导航:sideba...

  • 移动导航类型

    tab 导航 抽屉导航 list导航 九宫格导航 复合导航

  • APP导航设计模式

    导航主要分为两大类,横向和纵向。横向的导航有:标签导航、舵式导航、tab导航、轮播导航;纵向的导航有:宫格导航、下...

  • 标签式导航的设计思路

    导航分很多类别,如标签导航、抽屉式导航、九宫格导航、混合组合导航、列表式导航、Tab导航、平铺导航等等。之前在我的...

  • Bootstrap-导航菜单-2018.07.07

    Bootstrap-导航菜单 nav 标签式导航 胶囊式导航 垂直胶囊式导航 两端对齐导航 导航元素下拉菜单

  • iOS应用导航模式

    IOS导航模式: 标签导航模式、桌面式模式、抽屉式导航、列表式导航、 点聚式导航、下拉菜单式导航、轮播导航 接下来...

  • Tailwind Navbar

    导航栏 PC导航栏仿Airbnb导航条 PC导航条添加图标 PC导航条上图下字 移动端导航条

  • 程序员导航

    转载自:程序员不可不知的导航 导航网址 极客导航 导航湾 nice导航 GitFox 程序员工具箱 沃克导航 去瞧瞧导航

网友评论

      本文标题:ReactNactive导航

      本文链接:https://www.haomeiwen.com/subject/uevaihtx.html