flutter使用动态路由传参的最小案例

flutter中使用动态路由传递参数的封装案例,子组件页面只需要接收arguments参数即可,参数是一个map,里面包含有所需要的参数,类似于json。在MaterialApp中配置onGenerateRoute,然后动态判断传递参数:

routes列表:

    // 命名路由传参
    Map routes = {
      "/home": (content) => Home(),
      "/search": (context) => SearchPage(),
      // 传递参数的形式
      "/store": (context, {arguments}) => Store(arguments: arguments)
    };

 onGenerateRoute函数:

      onGenerateRoute: (RouteSettings settings) {
        // 获取声明的路由页面函数
        var pageBuilder = routes[settings.name];
        if (pageBuilder != null) {
          if (settings.arguments != null) {
            // 创建路由页面并携带参数
            return MaterialPageRoute(
                builder: (context) =>
                    pageBuilder(context, arguments: settings.arguments));
          } else {
            return MaterialPageRoute(
                builder: (context) => pageBuilder(context));
          }
        }
        return MaterialPageRoute(builder: (context) => HomePage());
      }

然后在路由跳转的时候, 使用pushNamed进行传递参数:

                Navigator.pushNamed(context, "/store",
                    arguments: {"title": "京东首页", "price": 100});

在子组件里面,定义并接收参数:

import "package:flutter/material.dart";

class Store extends StatefulWidget {
  const Store({super.key, this.arguments});

  final dynamic arguments;

  @override
  State<Store> createState() => _StoreState();
}

class _StoreState extends State<Store> {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text(
            "${widget.arguments != null ? widget.arguments['title'] : "ThirdPage"}"),
      ),
      body: Center(
        child: ElevatedButton(
          child: Text("返回上一家"),
          onPressed: () {
            print("返回上一家");
            Navigator.pop(context);
          },
        ),
      ),
    );
  }
}

最后的优化,可以将route封装成一个dart包,然后引入到materialApp中,让逻辑更清晰:

router.dart源代码: 

import "package:flutter/material.dart";
import "../main.dart";
import "../pages/home.dart";
import "../pages/search.dart";
import "../pages/store.dart";

// 命名路由传参
Map routes = {
  "/home": (content) => Home(),
  "/search": (context) => SearchPage(),
  "/store": (context, {arguments}) => Store(arguments: arguments)
};

// 定义一个函数,并返回MaterialPageRoute
var onGenerateRoute = (RouteSettings settings) {
  var pageBuilder = routes[settings.name];
  if (pageBuilder != null) {
    if (settings.arguments != null) {
      // 创建路由页面并携带参数
      return MaterialPageRoute(
          builder: (context) =>
              pageBuilder(context, arguments: settings.arguments));
    } else {
      return MaterialPageRoute(builder: (context) => pageBuilder(context));
    }
  }
  return MaterialPageRoute(builder: (context) => HomePage());
};

在materialApp中引入:

​​​​​​​ 

 

最后的效果图:

相关推荐

  1. 程序页面方法?

    2023-12-06 22:04:01       44 阅读
  2. Vue

    2023-12-06 22:04:01       51 阅读
  3. Vue2-动态基本用法

    2023-12-06 22:04:01       54 阅读
  4. 程序页面方法

    2023-12-06 22:04:01       30 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2023-12-06 22:04:01       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2023-12-06 22:04:01       106 阅读
  3. 在Django里面运行非项目文件

    2023-12-06 22:04:01       87 阅读
  4. Python语言-面向对象

    2023-12-06 22:04:01       96 阅读

热门阅读

  1. 阿里云Mysql5.7 数据库恢复 qp.xb文件恢复数据

    2023-12-06 22:04:01       64 阅读
  2. Lab 5: Python Lists, Trees

    2023-12-06 22:04:01       59 阅读
  3. 浅谈Elasticsearch安全和权限管理

    2023-12-06 22:04:01       47 阅读
  4. Ubuntu22.04 安装nvida-docker2和改路径

    2023-12-06 22:04:01       46 阅读
  5. ElasticSearch之cat indices API

    2023-12-06 22:04:01       54 阅读
  6. 【C++刷题】校招笔试编程题第一辑

    2023-12-06 22:04:01       46 阅读
  7. 洛谷P1269 信号放大器(树形数据)

    2023-12-06 22:04:01       42 阅读
  8. 前端中级开发:突破瓶颈,迈向更高峰

    2023-12-06 22:04:01       52 阅读
  9. Django rest froamwork-HyperlinkedModelSerializer

    2023-12-06 22:04:01       56 阅读
  10. 基于 HarmonyOS 的用户登录界面实现

    2023-12-06 22:04:01       71 阅读