Flutter Navigator路由传参怎么实现
发表于:2024-11-25 作者:千家信息网编辑
千家信息网最后更新 2024年11月25日,今天小编给大家分享一下Flutter Navigator路由传参怎么实现的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有
千家信息网最后更新 2024年11月25日Flutter Navigator路由传参怎么实现
今天小编给大家分享一下Flutter Navigator路由传参怎么实现的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。
Flutter中的默认导航分成两种,一种是命名的路由,一种是构建路由。
一、命名路由传参
应用入口处定义路由表
class MyApp extends StatelessWidget { const MyApp({Key? key}) : super(key: key); @override Widget build(BuildContext context) { return MaterialApp( debugShowCheckedModeBanner: false, // 隐藏预览中的debug title: 'Flutter Demo', routes: { '/': (context) => const HomePage(), "menu": (context) => const MenuPage() }, ); }}
// 定义HomePageclass HomePage extends StatelessWidget { const HomePage({Key? key}) : super(key: key); @override Widget build(BuildContext context) { return Scaffold( appBar: AppBar( title: const Text("登录"), ), body: ElevatedButton( onPressed: () async { // 实现路由跳转 var result = await Navigator.pushNamed(context, 'menu', arguments: {'name': 'title'}); print(result); }, child: const Text('登录'), ), ); }}
// 定义MenuPageclass MenuPage extends StatelessWidget { const MenuPage({Key? key}) : super(key: key); @override // 接收传参 Widget build(BuildContext context) { dynamic argumentsData = ModalRoute.of(context)?.settings.arguments; return Scaffold( appBar: AppBar( title: Text('菜单' + argumentsData.toString()), ), body: ElevatedButton( onPressed: () { Navigator.pop(context, {'name': "Navigator.pop传参"}); }, child: const Text("返回"), ), ); }}
二、构建路由传参
从HomePage页面跳转MenuPage页面时,携带参数
第一种方式:
// 定义HomePageclass HomePage extends StatelessWidget { const HomePage ({Key? key}) : super(key: key); @override Widget build(BuildContext context) { return Scaffold( appBar: AppBar( title: const Text("登录"), ), body: ElevatedButton( onPressed: () { // 实现路由跳转 Navigator.push( context, MaterialPageRoute( builder: (context) => const MenuPage( title: '菜单123', ), // 需要跳转的页面 ), // 修改路由的名称、信息等 ); }, child: const Text('登录'), ), ); }}
// 定义MenuPageclass MenuPage extends StatelessWidget { // 定义接收的字段 final String title; const MenuPage({Key? key, required this.title}) : super(key: key); @override Widget build(BuildContext context) { return Scaffold( appBar: AppBar( title: Text(title), ), body: ElevatedButton( onPressed: () { Navigator.pop(context); }, child: const Text("返回"), ), ); }}
第二种方式:
// 定义HomePageclass HomePage extends StatelessWidget { const HomePage({Key? key}) : super(key: key); @override Widget build(BuildContext context) { return Scaffold( appBar: AppBar( title: const Text("登录"), ), body: ElevatedButton( onPressed: () { // 实现路由跳转 Navigator.push( context, MaterialPageRoute( builder: (context) => const MenuPage(), // 修改路由的名称、信息等 settings: const RouteSettings( name: '菜单', arguments: {"name": '123'}) // 需要跳转的页面 ), ); }, child: const Text('登录'), ), ); }}
// 定义MenuPageclass MenuPage extends StatelessWidget { const MenuPage({Key? key}) : super(key: key); @override // 接收传参 Widget build(BuildContext context) { dynamic argumentsData = ModalRoute.of(context)?.settings.arguments; return Scaffold( appBar: AppBar( title: Text('菜单' + argumentsData.toString()), ), body: ElevatedButton( onPressed: () { Navigator.pop(context); }, child: const Text("返回"), ), ); }}
从MenuPage页面返回HomePage页面时,携带参数
// 定义HomePageclass HomePage extends StatelessWidget { const HomePage ({Key? key}) : super(key: key);; @override Widget build(BuildContext context) { return Scaffold( appBar: AppBar( title: const Text("登录"), ), body: ElevatedButton( onPressed: () async { // 实现路由跳转 var result = await Navigator.push( context, MaterialPageRoute( builder: (context) => const MenuPage(), ), ); print(result); }, child: const Text('登录'), ), ); }}
// 定义MenuPageclass MenuPage extends StatelessWidget { const MenuPage({Key? key}) : super(key: key); @override // 接收传参 Widget build(BuildContext context) { return Scaffold( appBar: AppBar( title: const Text('菜单'), ), body: ElevatedButton( onPressed: () { Navigator.pop(context, {'name': "Navigator.pop传参"}); }, child: const Text("返回"), ), ); }}
以上就是"Flutter Navigator路由传参怎么实现"这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注行业资讯频道。
路由
登录
页面
菜单
知识
篇文章
信息
内容
参数
名称
方式
不同
很大
入口
入口处
大部分
字段
就是
更多
知识点
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
计算机网络技术高职教材
数据库的表结构可以导出来吗
数字媒体艺术和计算机网络技术
服务器和交换机用什么类型端口
数据库的数据定义功能
网游修改如何骗过服务器
数据库与信息系统第六章
软件开发的人怎么称呼
新能源车载网络技术论文
公司内部软件开发规定
数字媒体网络技术软件
数据库技术性能水平 指标
树立网络安全意识争做
php 服务器租用
access数据库备注型
身边网络安全故事绘画
mfc tcp 服务器
查看表格数据库语句
L1low物理层软件开发
数据库关系中的键是什么
网络安全的英语小报
鬼魂服务器区域为什么调换不了
软件开发团队合作的精神
武汉大学网络安全调剂
互联网发展带来的科技
创新科技软件开发
系统网络安全的测试是什么
网络技术人员头像
山东大千网络技术有限公司
数据库全外连接左外连接吗