Flutter 日记App-get全局路由

路由配置

less 复制代码
@override
Widget build(BuildContext context) {
  return GetMaterialApp(
  //路由页 管理
    getPages: SSLRoutes.pages,
    //初始路由
    initialRoute: SSLRoutes.root_routes,
    //主页
    home: const SSLRootRoute(),
  );
}

路由管理类

php 复制代码
abstract class SSLRoutes{
//将类名进行常量化,防止直接使用字符串
  static const root_routes = "/";
  static const root_main = "/RootMain";
  static const root_charts = "/RootCharts";
  static const root_setting = "/RootSetting";
  static const home_add_record = "/homeAddRecord";
  static const home_RecordList = "/recordList";
  //路由表,可以看到每一个路由对应的一个GetPage,GetPage中有很多的属性,大家可以进去看下,在这里还可以设置一些默认的参数。
  static List<GetPage> pages = [
    GetPage(name: root_routes, page: ()=> const SSLRootRoute()),
    GetPage(name: root_main, page: ()=> const SSLHome()),
    GetPage(name: home_add_record, page: ()=> const SSLAddRecord()),
    GetPage(name: home_add_dream, page: ()=> const SSLAddDream()),
    GetPage(name: home_RecordList, page: ()=> const SSLRecordList()),
  ];
}

用法

scss 复制代码
//跳转到添加页,带上参数信息,参数可接收任意类型数据,同时用dreamInfo接收一个返回数据
dreamInfo = await Get.toNamed(SSLRoutes.home_add_dream,arguments: dreamInfo);
获取到返回数据后刷新界面
setState(() {

});
//返回上个界面,并带上参数dream
Get.back(result: dream);

小知识点

在传参时,可能有些参数不确定,或者不同页面进入带的参数不同,则可以添加类型判断

csharp 复制代码
//获取传入的参数
var record = Get.arguments;
//判断参数类型
if (record != null){
  if (record is String){
    dreamId = record;
  }else if (record is RecordModel){
  ......
}

总结

Get的路由管理也比较容易使用,需要注意的是多页面跳转的时候,注意参数类型的判断和参数格式的处理,由于框架限制,通常是只能传一个参数,可以使用数组等多种方式进行灵活使用。针对特殊的界面可以单独定义一个函数,将参数直接带入。

相关推荐
小哥Mark10 分钟前
Flutter开发鸿蒙年味 + 实用实战应用|春节祝福:列表选卡 + 贴纸拖动 + 截图分享
flutter·harmonyos·鸿蒙
王码码203528 分钟前
Flutter for OpenHarmony 实战之基础组件:第十六篇 约束布局 ConstrainedBox 与 AspectRatio
flutter·harmonyos
2501_9159184136 分钟前
在 iOS 环境下查看 App 详细信息与文件目录
android·ios·小程序·https·uni-app·iphone·webview
王码码20351 小时前
Flutter for OpenHarmony 实战之基础组件:第十八篇 布局终极者 CustomScrollView 与 Slivers
flutter·harmonyos
ujainu1 小时前
Flutter + OpenHarmony 实战:构建清晰、健壮的三屏状态流转
flutter·游戏·openharmony
铅笔侠_小龙虾1 小时前
Flutter 组件层级关系
前端·flutter·servlet
一起养小猫1 小时前
Flutter for OpenHarmony 实战:打地鼠游戏完整开发指南
flutter·游戏·harmonyos
一起养小猫1 小时前
Flutter for OpenHarmony 实战:打地鼠游戏难度设计与平衡性
flutter·游戏·harmonyos
ujainu1 小时前
Flutter + OpenHarmony 实战:构建独立可复用的皮肤选择界面
flutter·游戏·openharmony
Betelgeuse761 小时前
【Flutter For OpenHarmony】 阶段复盘:从单页Demo到模块化App
flutter·ui·华为·交互·harmonyos