Flutter GetX 之 路由管理

路由管理是插件GetX常用功能之一,为什么说之一呢?因为GetX的功能远不止路由管理这么简单。

GetX的重要功能如下:

|------------|------------|-----------|----------|-----------------|-----------------|----------------|
| 1、路由管理 | 2、状态管理 | 3、国际化 | 4、主题 | 5、GetUtil工具 | 6、dialog 弹框 | 7、snackbar |

其实上面功能介绍的还是不够详细,GetX还支持网络请求等

今天主要介绍一下GetX的路由管理

首先需要将Flutter项目入口MaterialApp 替换成GetX提供的GetMaterialApp,代码示例如下:

Dart 复制代码
return MaterialApp(
    home: MyHomePage(),
);

Dart 复制代码
return GetMaterialApp(
   home: MyHomePage(),
);

接下来就是创建路由管理类 router_util.dart,这个类负责统一把所有页面进行路由设置,GetX设置路由代码如下:

GetPage(name: "/login", page: () => LoginPage()),

GetPage 便是设置一个类的路由

"/login" 为使用过程中的Key,page: 为指向的页面。

下面是路由管理类的完整代码

Dart 复制代码
import 'package:get/get.dart';

import '../view/login/forget/forget_view.dart';
import '../view/login/login_view.dart';
import '../view/login/register/register_view.dart';
import '../view/main/tab_bar/tab_bar_view.dart';

List<GetPage> get pages => [
      GetPage(name: "/login", page: () => LoginPage()),
      GetPage(name: "/tabbar", page: () => TabBarPage()),
      GetPage(name: "/register", page: () => RegisterPage()),
      GetPage(name: "/password", page: () => ForgetPage()),
    ];

我们将路由管理设置完以后,下面就是路由注入了,注入代码简单,便是将pages放入到的getPages中即可。当然当我们使用路由管理后,我们需要设置一下程序入口initialRoute,完整代码如下:

Dart 复制代码
return GetMaterialApp(
  getPages: pages,
  initialRoute: "/login",
);

到此就完成了路由管理的配置,下面介绍一下路由的使用,推荐使用++别名路由++。

普通路由

页面跳转

Dart 复制代码
Get.to(RegisterPage());

带参数

Dart 复制代码
Get.to(RegisterPage(),arguments: "范型");

arguments 未范型,什么类型都可以

参数获取

Dart 复制代码
dynamic arguments = Get.arguments;

off: 进入下一个界面,且导航没有返回

Dart 复制代码
Get.off(RegisterPage());

offAll: 进入下一个界面并取消之前的所有路由

Dart 复制代码
Get.offAll(RegisterPage());

**back:**返回

Dart 复制代码
Get.back();

返回时带参数

Dart 复制代码
Get.back(result: '返回参数');

**result:**也为范型,可为任何类型

获取参数

Dart 复制代码
var result = await Get.to(RegisterPage());

别名路由

使用方法与普通路由基本相同,只是方法上多了 Named

路由跳转

Dart 复制代码
Get.toNamed("/register");

带参数

Dart 复制代码
Get.toNamed("/register",arguments: "范型");

也可以想Vue里面的方式进行跳转和传参(不推荐,使用不方便

Dart 复制代码
Get.toNamed("/register?id=1&name=王哪跑");

获取参数和普通路由一致

使用Vue方式传参获取参数方式如下

Dart 复制代码
Get.parameters['id']

进入下一个界面并取消之前的所有路由

Dart 复制代码
Get.offAllNamed("/tabbar");

返回和返回带参数使用方式与普通路由保持一致。

到此就完成了GetX路由管理的使用。

GetX功能很强大,路由管理是比较常用的功能。

GetX后续功能将会持续介绍使用,下一片文章会介绍一下GetX状态管理

相关推荐
行者9615 小时前
Flutter适配OpenHarmony:国际化i18n实现中的常见陷阱与解决方案
开发语言·javascript·flutter·harmonyos·鸿蒙
wey60815 小时前
fiuckjs 基于react的flutter动态化方案
flutter
行者9617 小时前
Flutter在鸿蒙平台实现自适应步骤条组件的完整指南
flutter·harmonyos·鸿蒙
行者9619 小时前
Flutter与OpenHarmony深度整合:打造高性能自定义图表组件
flutter·harmonyos·鸿蒙
行者9619 小时前
Flutter适配OpenHarmony:高效数据筛选组件的设计与实现
开发语言·前端·flutter·harmonyos·鸿蒙
yujunlong391920 小时前
Dart Frog 后端开发实战:轻量级 API 构建与生产环境调优
flutter·dart·dart frog
Swuagg20 小时前
Flutter 探索入门
flutter
kirk_wang20 小时前
当Flutter的并发利器遇上鸿蒙:flutter_isolate的OHOS适配之旅
flutter·移动开发·跨平台·arkts·鸿蒙
AiFlutter21 小时前
五、交互行为(01):按钮
flutter·低代码·低代码平台·aiflutter·aiflutter低代码
kirk_wang21 小时前
Flutter艺术探索-Flutter表单组件:TextField与验证处理
flutter·移动开发·flutter教程·移动开发教程