当前位置: 首页 > news >正文

react native使用TS实现路由

一、入口文件app.jsx的配置

       入口文件最好还是要保留jsx

import { NavigationContainer } from '@react-navigation/native';
import { navigationRef } from "./src/views/RootNavigation";const App = () => {return(<NavigationContainer ref={navigationRef}><StackRouter /></NavigationContainer>)
}

二、HomeScreen自定义你的tabbar导航

一般情况下项目里都是自定义的tababr,每个项目不一样,我这里就不过多展示

三、在应用的任何地方使用的导航功能

import { createNavigationContainerRef } from "@react-navigation/native";
export const navigationRef = createNavigationContainerRef();
export function navigate(name, params) {if (navigationRef.isReady()) {navigationRef.navigate(name, params);}
}

四、配置router.tsx和types.tsx

        router.tsx

 首先tababr页面可以用const的方式引入,其他页面可以用lazy的方式懒加载引入

核心代码

import { createNativeStackNavigator } from "@react-navigation/native-stack";const Stack = createNativeStackNavigator<RootStackParamList>();export default function StackRouter() {return (//示例<Stack.NavigatorinitialRouteName="HomeScreen"screenOptions={{ headerShown: false }}><Stack.Screen name="HomeScreen" component={HomeScreen} /></Stack.Navigator>
)}

types.tsx

核心代码

import { StackNavigationProp } from '@react-navigation/stack';
import { RouteProp } from '@react-navigation/native';export type RootStackParamList = {HomeScreen: undefined;Search: undefined;NpcMessage: undefined;Interactive: undefined;Example: { data: Array<string> }; //示例// 新添加的路由及其参数也应该在这里定义
};//需要用参数的时候需要导出一个 RouteProp
//需要用到页面跳转的时候,需要导出一个StackNavigationProp
//如果两者都需要,就需要导出两个
//import { useNavigation ,useRoute } from '@react-navigation/native'; 目标页面useNavigation是导航,useRoute是route//定义Interactive页面路由跳转
export type InteractiveNavigationProp = StackNavigationProp<RootStackParamList, 'Interactive'>;
export type InteractiveRouteProp = StackNavigationProp<RootStackParamList, 'Interactive'>;
// 定义Example页面的路由参数类型
export type ExampleRouteProp = RouteProp<RootStackParamList, 'Example'>;
// 更多类型定义...

五、页面中使用

import { useNavigation, useRoute } from '@react-navigation/native';
import { InteractiveNavigationProp,InteractiveRouteProp } from '../../router/types'const Interactive = () => {const navigation = useNavigation<InteractiveNavigationProp>();const router = useRoute<InteractiveRouteProp>}export default Interactive;

原本我们项目是js,由于最近在学TS,就在项目上慢慢局部引入TS,如果有问题或者建议,欢迎提问。

http://www.lryc.cn/news/317832.html

相关文章:

  • 手机充值的功能测试框架 - 测试要点
  • U盘启动盘 制作Linux Ubuntu CentOS系统启动盘 系统安装
  • Nodejs 第五十四章(net)
  • 渗透测试修复笔记 - 04 nacos 可能会导致未经授权的用户获取到系统中的敏感信息的漏洞
  • 初级代码游戏的专栏介绍与文章目录
  • 【Redis系列】深入了解 Redis:一种高性能的内存数据库
  • C语言例:表达式(a=2,3),a+1的值
  • 基于java的公寓报修管理系统设计与实现(程序+文档+数据库)
  • Lua 函数前的冒号和点号,你知道他们的区别吗?
  • 4、设计模式之建造者模式(Builder)
  • 网工内推 | 上市公司网工,IE认证优先,最高18K*13薪,包吃住
  • SQL Server 技术100问?
  • 鸿蒙不再适合JS语言开发
  • Python环境搭建 -- Python与PyCharm安装
  • OSCP靶场--Astronaut
  • Springboot 使用【过滤器】实现在请求到达 Controller 之前修改请求体参数和在结果返回之前修改响应体
  • Unity 3D常用的数据结构
  • h5唤起微信小程序
  • 面向对象(精髓)变继承关系为组和关系(_Decorator模式)
  • MES系统在智能生产中的重要作用
  • 2024.3.13每日一题
  • YOLOv5 | 涨点复现!YOLOv5添加BiFPN有效提升目标检测精度
  • 【Nut3】nuxt.config.ts项目nuxt配置文件介绍
  • 区块链技术的革命性影响
  • 多线程(volatile)
  • 蓝桥杯 填空 卡片
  • ELK介绍使用
  • 【UE5】非持枪状态蹲姿移动的动画混合空间
  • Windows C++ TCP开发(使用select函数以及设置非阻塞/Reuse属性)
  • ARM TrustZone技术解析:构建嵌入式系统的安全扩展基石