Flutter路由跳转的两种方式

1.基本路由跳转:文件引入在你要跳转的页面引入

复制代码
        ElevatedButton(
            onPressed: () {
              Navigator.of(context).push(
                MaterialPageRoute(
                  builder: (BuildContext context) {
                    return const NewsPage(
                      arguments: {
                        "title": "基本路由新闻页面传值",
                        "aid": 88888888,
                      },
                    );
                  },
                ),
              );
            },
            child: const Text('基本路由跳转新闻页面(传值)'),
          ),

2.命名路由跳转:此时文件在main.dart文件引入

复制代码
        ElevatedButton(
            onPressed: () {
              Navigator.pushNamed(context, '/news', arguments: {
                "title": "命名路由新闻页面传值",
                "aid": 999999999,
              });
            },
            child: const Text('命名路由跳转新闻页面(传值)'),
          ),

此时需要在main.dart页面配置相关属性

复制代码
import 'package:flutter/material.dart';
import "./pages/namedRoutes/tabs.dart";
import "./pages/namedRoutes/news.dart";
import "./pages/namedRoutes/form.dart";

void main() {
  runApp(MyApp());
}

class MyApp extends StatelessWidget {
  // 1.配置路由表
  final Map routes = {
    "/": (context) => const Tabs(),
    "/form": (context) => const FormPage(),
    "/news": (context, {arguments}) => NewsPage(arguments: arguments),
  };
  MyApp({super.key});

  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: "Flutter Demo",
      debugShowCheckedModeBanner: false, // 去除debug标签
      theme: ThemeData(
        primarySwatch: Colors.blue,
        primaryColor: Colors.red,
      ),
      // home: const Tabs(),
      //2、调用onGenerateRoute处理
      onGenerateRoute: (RouteSettings settings) {
        // 统一处理
        final String? name = settings.name;
        final Function? pageContentBuilder = routes[name];
        if (pageContentBuilder != null) {
          if (settings.arguments != null) {
            final Route route = MaterialPageRoute(
                builder: (context) =>
                    pageContentBuilder(context, arguments: settings.arguments));
            return route;
          } else {
            final Route route = MaterialPageRoute(
                builder: (context) => pageContentBuilder(context));
            return route;
          }
        }
        return null;
      },
    );
  }
}
相关推荐
LaughingZhu18 小时前
Product Hunt 每日热榜 | 2026-05-21
前端·人工智能·经验分享·chatgpt·html
怕浪猫18 小时前
Electron 开发实战(一):从零入门核心基础与环境搭建
前端·electron·ai编程
小鹏linux18 小时前
Ubuntu 22.04 部署开源免费具有精美现代web页面的Casdoor账号管理系统
linux·前端·ubuntu·开源·堡垒机
前端若水19 小时前
会话管理:创建、切换、删除对话历史
前端·人工智能·python·react.js
Bigger19 小时前
mini-cc:一个轻量级 AI 编程助手的诞生
前端·ai编程·claude
涵涵(互关)20 小时前
Naive-ui树型选择器只显示根节点
前端·ui·vue
BY组态20 小时前
Ricon组态系统最佳实践:从零开始构建物联网监控平台
前端·物联网·iot·web组态·组态
BY组态20 小时前
Ricon组态系统vs传统组态软件:为什么选择新一代Web组态平台
前端·物联网·iot·web组态·组态
SoaringHeart20 小时前
Flutter进阶:OverlayEntry 插入图层管理器 NOverlayZIndexManager
前端·flutter
放下华子我只抽RuiKe520 小时前
React 从入门到生产(四):自定义 Hook
前端·javascript·人工智能·深度学习·react.js·自然语言处理·前端框架