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

相关推荐
百分三十七1 小时前
最新的 Dart sdk 安装教程
flutter·dart
赵财猫._.1 小时前
【Flutter x 鸿蒙】第三篇:鸿蒙特色UI组件与Flutter的融合使用
flutter·ui·harmonyos
晚霞的不甘3 小时前
实战:从零构建一个支持手机、手表与车机的 Flutter 全场景健康应用
flutter·智能手机
kirk_wang3 小时前
当Flutter遇见纯血鸿蒙:SQLite兼容适配的实战与思考
flutter·移动开发·跨平台·arkts·鸿蒙
克喵的水银蛇5 小时前
Flutter 通用输入框封装实战:带校验 / 清除 / 密码切换的 InputWidget
前端·javascript·flutter
小蜜蜂嗡嗡17 小时前
flutter namespace问题
android·flutter
克喵的水银蛇17 小时前
Flutter 适配实战:屏幕适配 + 暗黑模式 + 多语言
前端·javascript·flutter
西西学代码18 小时前
flutter---自定义白噪音UI
flutter
肠胃炎18 小时前
Flutter ListView 组件及各种模式
flutter