26、Flutter中命名路由
Flutter 中的命名路由
main.dart中配置路由
void main() {
runApp(MaterialApp(
theme: ThemeData(
appBarTheme: const AppBarTheme(
color: Colors.blue, // 设置导航栏颜色 (新版本的设置方法)
),
),
// home: Scaffold(body: MyFlutter1())
initialRoute: "/", //初始化路由
routes: {
"/": (contxt) => const MyFlutter1(),
"/form": (contxt) => const FormPage(),
// "/news": (contxt)=>const SearchMyApp(),
"/news": (contxt) {
return const SearchMyApp();
}, //类似
},
));
}
跳转路由
class TimePag extends StatefulWidget {
const TimePag({super.key});
@override
State<TimePag> createState() => _TimePagState();
}
class _TimePagState extends State<TimePag> {
@override
Widget build(BuildContext context) {
return Column(
children: [
ElevatedButton(
onPressed: () {
Navigator.pushNamed(context, "/news"); //命名路由跳转
},
child: const Text("命名路由跳转"))
],
);
}
}
Flutter 中的命名路由传值
配置onGenerateRoute
class MyApp1 extends StatelessWidget {
//1.配置路由
Map routes = {
"/": (contxt) => const MyFlutter1(),
"/form": (contxt) => const FormPage(),
// "/news": (contxt)=>const SearchMyApp(),
"/news": (contxt, {arguments}) {
return SearchMyApp(arguments: arguments); //命名路由传参
}, //类似
};
MyApp1({super.key});
@override
Widget build(BuildContext context) {
return MaterialApp(
theme: ThemeData(
appBarTheme: const AppBarTheme(
color: Colors.blue, // 设置导航栏颜色 (新版本的设置方法)
),
),
// home: Scaffold(body: MyFlutter1())
initialRoute: "/", //初始化路由
//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;
},
);
}
}
定义页面接收arguments传参
//其他页面跳转到本页面进行传参
class SearchMyApp extends StatefulWidget { final Map arguments; const SearchMyApp({super.key,required this.arguments}); //必须传入 @override
State<SearchMyApp> createState() => _SearchMyAppState();
} class _SearchMyAppState extends State<SearchMyApp> { @override
void initState() {
super.initState();
print(widget.arguments); //参数
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text("新闻页面"),
),
body: Center(child: Text("内容")),
);
}
}
跳转页面实现传参
class TimePag extends StatefulWidget {
const TimePag({super.key});
@override
State<TimePag> createState() => _TimePagState();
}
class _TimePagState extends State<TimePag> {
@override
Widget build(BuildContext context) {
return Column(
children: [
ElevatedButton(
onPressed: () {
Navigator.pushNamed(context, "/news",
arguments: {"title": "我是命名路由传的值", "id": 5}); //命名路由跳转
},
child: const Text("命名路由跳转传值"))
],
);
}
}
Flutter 中的命名路由单独抽离到一个文件
新建routers/routers.dart 配置路由
import 'package:app_flutter01/pages/form.dart';
import 'package:app_flutter01/pages/news.dart';
import 'package:app_flutter01/pages/tabs.dart';
import 'package:flutter/material.dart'; //1.配置路由
Map routes = {
"/": (contxt) => const MyFlutter1(),
"/form": (contxt) => const FormPage(),
// "/news": (contxt)=>const SearchMyApp(),
"/news": (contxt, {arguments}) {
return SearchMyApp(arguments: arguments); //命名路由传参
}, //类似
}; // onGenerateRoute处理(固定写法) 这个方法也相当于一个中间件,这里可以做权限判断
var 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;
};
修改main.dart
class MyApp1 extends StatelessWidget {
MyApp1({super.key});
@override
Widget build(BuildContext context) {
return MaterialApp(
theme: ThemeData(
appBarTheme: const AppBarTheme(
color: Colors.blue, // 设置导航栏颜色 (新版本的设置方法)
),
),
// home: Scaffold(body: MyFlutter1())
initialRoute: "/", //初始化路由
//2、调用onGenerateRoute处理(固定写法)
onGenerateRoute: onGenerateRoute,
);
}
}
实现页面跳转传值
class TimePag extends StatefulWidget {
const TimePag({super.key});
@override
State<TimePag> createState() => _TimePagState();
}
class _TimePagState extends State<TimePag> {
@override
Widget build(BuildContext context) {
return Column(
children: [
ElevatedButton(
onPressed: () {
Navigator.pushNamed(context, "/news",
arguments: {"title": "我是命名路由传的值", "id": 5}); //命名路由跳转
},
child: const Text("命名路由跳转传值"))
],
);
}
}
Flutter 返回上一级路由
Navigator.of(context).pop();
Flutter 中替换路由
Navigator.of(context).pushReplacementNamed('/registerSecond');
Flutter 返回到根路由
Navigator.of(context).pushAndRemoveUntil(
MaterialPageRoute(builder: (BuildContext context) {
return const Tabs();
}), (route) => false);
Flutter Android 和Ios使用同样风格的路由跳转
import 'package:app_flutter01/pages/form.dart';
import 'package:app_flutter01/pages/news.dart';
import 'package:app_flutter01/pages/tabs.dart';
import 'package:flutter/material.dart'; //配置ios fen
import 'package:flutter/cupertino.dart'; /**
配置ios风格的路由
1、删掉material.dart引入
cupertino.dartimport 'package:flutter/cupertino.dart';
2、把MaterialPageRoute替换成CupertinoPageRoute
*/ //1.配置路由
Map routes = {
"/": (contxt) => const MyFlutter1(),
"/form": (contxt) => const FormPage(),
"/time": (contxt) => const MyFlutter1(), // "/news": (contxt)=>const SearchMyApp(),
"/news": (contxt, {arguments}) {
return SearchMyApp(arguments: arguments); //命名路由传参
}, //类似
}; // onGenerateRoute处理(固定写法) 这个方法也相当于一个中间件,这里可以做权限判断
var onGenerateRoute = (RouteSettings settings) {
// 统一处理
final String? name = settings.name; //获取命名路由的名称
final Function? pageContentBuilder = routes[name];
if (pageContentBuilder != null) {
if (settings.arguments != null) {
// final Route route = MaterialPageRoute( //路由效果
final Route route = CupertinoPageRoute(
builder: (context) =>
pageContentBuilder(context, arguments: settings.arguments));
return route;
} else {
final Route route =
MaterialPageRoute(builder: (context) => pageContentBuilder(context));
return route;
}
}
return null;
};
全局配置主题
return MaterialApp(
debugShowCheckedModeBanner: false,
title: 'Flutter Demo',
theme: ThemeData(
primarySwatch: Colors.blue,
appBarTheme: const AppBarTheme(
centerTitle: true, //标题居中
)
),
initialRoute: "/",
onGenerateRoute: onGenerateRoute,
);
命名路由跳转设置过度动画
//routers.dart 文件里直接加
class BackgroundPageRoute extends PageRouteBuilder {
final WidgetBuilder builder; BackgroundPageRoute({required this.builder})
: super(
pageBuilder: (context, animation, secondaryAnimation) => builder(context),
transitionsBuilder: (context, animation, secondaryAnimation, child) {
return Stack(
children: [
Positioned.fill(
child: Image.network(
'url',
fit: BoxFit.cover,
),
),
FadeTransition(
opacity: animation,
child: child,
),
],
);
},
);
} //单个使用(需要跳转的页面里) Navigator.push(
context,
BackgroundPageRoute(
builder: (context) => FormPage(),
),
); //全局使用(在routers.dart 里)
将final Route route = MaterialPageRoute( ....
换成 final Route route = BackgroundPageRoute( //使用BackgroundPageRoute ....
26、Flutter中命名路由的更多相关文章
- Flutter中管理路由栈的方法和应用
原文地址:https://www.jianshu.com/p/5df089d360e4 本文首先讲的Flutter中的路由,然后主要讲下Flutter中栈管理的几种方法. 了解下Route和Navig ...
- Flutter 中的路由
Flutter 中的路由通俗的讲就是页面跳转.在 Flutter 中通过 Navigator 组件管理路由导航. 并提供了管理堆栈的方法.如:Navigator.push 和 Navigator.po ...
- Flutter中的路由 路由替换 返回到根路由
一.Flutter 中返回到上一级页面 Navigator.of(context).pop(); 二.Flutter 中替换路由 比如我们从用户中心页面跳转到了 registerFirst 页面,然后 ...
- flutter中的路由跳转
在前面的基本路由和命名路由中,都演示了如何进行路由跳转,并且在路由跳转以后,可以借用系统自带的按钮就行返回上一级,当然了,也可以自定义按钮返回上一级. 返回上一级 在前面的例子中,当从Home.dar ...
- tornado中命名路由及反向解析使用
一. 命名路由: 通常路由写法为[ (r'/' , Handler), ... ] 以上路由写法无法实现命名, 使用命名路由需借助tornado提供的方法, 如下: [ tornado.web.url ...
- Flutter中的普通路由与命名路由(Navigator组件)
Flutter 中的路由通俗的讲就是页面跳转.在 Flutter 中通过 Navigator 组件管理路由导航.并提供了管理堆栈的方法.如:Navigator.push 和 Navigator.pop ...
- Flutter 中的普通路由、普通路由传值、 命名路由、命名路由传值
一.Flutter 中的路由 Flutter 中的路由通俗的讲就是页面跳转.在 Flutter 中通过 Navigator 组件管理路由导航.并提供了管理堆栈的方法.如:Navigator.push ...
- Flutter 中的基本路由
Flutter 中的路由通俗的讲就是页面跳转.在 Flutter 中通过 Navigator 组件管理路由导航,并提供了管理堆栈的方法.如:Navigator.push 和 Navigator.pop ...
- 16Flutter中的路由 基本路由 基本路由跳转传值(上)
/* Flutter中的普通路由.普通路由传值.命名路由.命名路由传值 Flutter中的路由通俗的讲就是页面跳转.在Flutter中通过Navigator组件管理路由导航. 并提供了管理堆栈的方法. ...
- flutter中的命名路由
命名路由是区别于基本路由的一种存在,方便于大型项目中路由的统一管理,现在,在前面基本路由的项目基础上实现实现命名路由. 使用步骤 路由配置 命名路由在使用前,需要在根组件main.dart中进行简单的 ...
随机推荐
- Python面向对象——property装饰器、继承(与python2不同点)、多继承(优缺点、Mixins)、属性查找、多继承带来的菱形问题
文章目录 内容回顾 property装饰器 继承 与python2的差别 多继承 为何要用继承 如何实现继承 属性查找 多继承带来的菱形问题 总结: 作业 内容回顾 1.封装=>整合 人的对象. ...
- C#学习笔记--变量类型的转换
变量类型的转化: 转换原则 同类型的大的可以装小的,小类型的装大的就需要强制转换. 隐式转换: 同种类型的转换: //有符号 long-->int-->short-->sbyte l ...
- 使用Eclipse生成CHM帮助文档(图解)
使用Eclipse生成CHM帮助文档(图解) 博客分类: System Operate javadoc生成chm文档java生成api帮助文档api帮助文档生成工具 Eclipse JavaDoc和j ...
- 基于matomo实现业务数据埋点采集上报
matomo是一款Google-analytics数据埋点采集上报的平替方案,可保护您的数据和客户的隐私:正如它官网的slogan: Google Analytics alternative that ...
- virsh domxxx命令
1. 摘要信息类 1.1 dominfo 获取配置等摘要信息 [root@hyperhost ~]# virsh dominfo --domain centos7.6 Id: 1 Name: cent ...
- 数据结构与算法(LeetCode) 第二节 链表结构、栈、队列、递归行为、哈希表和有序表
一.链表结构 1.单向链表节点结构 public class Node{ public int value; public Node next; public Node(int data){ valu ...
- 8.3随记之Ubuntu 系统中修改 DNS 的两种办法和暗链
8.3 随记 在 Ubuntu 系统中修改 DNS 的两种办法 在终端进行修改编辑 sudo nano /etc/resolv.conf 进行修改文件 例如:nameserver 8.8.8.8, 保 ...
- 不懂乐理,也能扒谱,基于openvpi将mp3转换为midi乐谱(Python3.10)
所谓"扒谱"是指通过听歌或观看演奏视频等方式,逐步分析和还原音乐作品的曲谱或乐谱的过程.它是音乐学习和演奏的一种常见方法,通常由音乐爱好者.乐手或学生使用. 在扒谱的过程中,人们会 ...
- AtCoder Beginner Contest 237 G - Range Sort Query
原题链接 G - Range Sort Query 思路: \(x\)是固定的,所以考虑将排序维护成0 1串,为\(p_i < x\)为\(0\),那么\(p_i \geq x\)为\(1\), ...
- 三维形体的表面积(3.25leetcode每日打卡)
在 N * N 的网格上,我们放置一些 1 * 1 * 1 的立方体. 每个值 v = grid[i][j] 表示 v 个正方体叠放在对应单元格 (i, j) 上. 请你返回最终形体的表面积. ...