Flutter路由3分钟学会

Flutter路由

最近在学习Flutter中有用到路由,借此回顾一下Flutter路由跳转的方式.

编写的TODO示例Demo总共有两个界面:

主界面;

编辑界面

1.编写路由地址信息

dart 复制代码
abstract final class AppRoutes {
  static const homeRoute = '/';
  static const addEditRoute = '/add_edit_route';
}

2.使用GoRouter

引入依赖

yaml 复制代码
go_router: ^16.0.0

编写GoRouter

dart 复制代码
import 'package:flutter/material.dart';
import 'package:go_router/go_router.dart';
import 'package:warm_todo/routing/routes.dart';
import 'package:warm_todo/ui/screens/todo_home_screen.dart';

import '../data/entity.dart';
import '../ui/screens/edit_todo_screen.dart';

final GoRouter goRouter = GoRouter(
  routes: [
    GoRoute( //父路由
      path: AppRoutes.homeRoute,
      builder: (BuildContext context, GoRouterState state) =>
          const TodoHomeScreen(),
      routes: [ //要在另一个屏幕之上显示屏幕,通过将其添加到父路由的 routes 列表中添加子路由:
        GoRoute( //子路由
          name: AppRoutes.addEditRoute, //配置命名路由,使用 name 参数
          path: AppRoutes.addEditRoute, //配置path,可根据 URL 导航到路由
          builder: (context, state) {
            //声明跳转子路由要传的参数信息  
            final Map<String, dynamic> params =
                state.extra as Map<String, dynamic>;
            final todo = params['editTodo'] as ToDo?; //todo传空,表示跳转的是添加TODO页面,不为空则是编辑TODO页面
            final isEdit = params['isEdit'] as bool; //这里另外传了是否编辑,嗯,看起来不传这个也行
              
            return EditTodoScreen(isEdit: isEdit, editTodo: todo);
          },
        ),
      ],
    ),
  ],
);

注:由于本人目前也是初学Flutter,关于GoRouter使用的更多细节,可查阅官方文档:go_router

配置GoRouter对象

要在应用中使用此配置,请使用 MaterialApp.routerCupertinoApp.router 构造函数并将 routerConfig 参数设置为您的 GoRouter 配置对象:

dart 复制代码
class MyApp extends StatelessWidget {
  const MyApp({super.key});

  // This widget is the root of your application.
  @override
  Widget build(BuildContext context) {
    return MaterialApp.router(
      routerConfig: goRouter, //配置GoRouter对象
      localizationsDelegates: AppLocalizations.localizationsDelegates,
      supportedLocales: [const Locale('en', 'US'), const Locale('zh', 'CN')],
      title: 'Flutter Demo',
      theme: ThemeData(colorScheme: .fromSeed(seedColor: Colors.deepPurple)),
    );
  }
}

3.跳转界面

配置完GoRouter就可以实现界面跳转了,我目前的示例项目是主页面跳转到子页面(编辑界面)

跳转界面(传值跳转)

dart 复制代码
onPressed: () {
    context.goNamed( //要使用名称导航到路由,调用 goNamed
        AppRoutes.addEditRoute,
        extra: {
            "isEdit": false,
            "editTodo": null,
        }
        // pathParameters: {"isEdit": "false"},
    );
}

返回上一个页面

dart 复制代码
onPressed: () {
    context.pop();
}

以上就是简单使用Flutter路由的方式了,恭喜!你学会了Flutter 路由跳转,Happpy Coding!

TODO项目地址:warm_todo

相关推荐
—Qeyser2 小时前
Flutter CustomScrollView 自定义滚动视图 - 完全指南
android·flutter·ios
奋斗的小青年!!3 小时前
Flutter在OpenHarmony上实现渐变文字动画的深度优化实践
前端·flutter·harmonyos·鸿蒙
鸣弦artha3 小时前
Flutter 框架跨平台鸿蒙开发 —— Image Widget 图片处理:圆角、裁剪、阴影
android·flutter·harmonyos
—Qeyser3 小时前
Flutter ListView 列表组件完全指南
android·flutter·ios
南村群童欺我老无力.3 小时前
Flutter 框架跨平台鸿蒙开发 - 从零打造一款精美天气App
flutter·华为·harmonyos
m0_748254663 小时前
Vue.js 模板语法基础
前端·vue.js·flutter
AiFlutter4 小时前
五、交互行为(06):滑杆
flutter·低代码·低代码平台·aiflutter·aiflutter低代码
kirk_wang4 小时前
Flutter `share_plus` 库在鸿蒙 OHOS 平台的分享功能适配实践
flutter·移动开发·跨平台·arkts·鸿蒙
西西学代码4 小时前
Flutter--扫描BLE设备
flutter
消失的旧时光-19434 小时前
Android + Flutter 混合架构全景图:从接入到系统的完整方法论
android·flutter