当前位置: 首页 > news >正文

flutter go_router 官方路由(一)基本使用

1 项目中添加最新的依赖
go_router: ^13.1.0

如下图所示,我当前使用的flutter版本为3.16.0
在这里插入图片描述

然后修改应用的入口函数如下:

import 'package:flutter/material.dart';
import 'package:go_router/go_router.dart';void main() {runApp(const MyApp());
}class MyApp extends StatelessWidget {const MyApp({super.key});Widget build(BuildContext context) {return MaterialApp.router(routerConfig: _router,title: 'Flutter Demo',theme: ThemeData(colorScheme: ColorScheme.fromSeed(seedColor: Colors.deepPurple),useMaterial3: true,),);// return MaterialApp(//   title: 'Flutter Demo',//   theme: ThemeData(//     colorScheme: ColorScheme.fromSeed(seedColor: Colors.deepPurple),//     useMaterial3: true,//   ),//   home:  MyHomePage(),// );}
}

其实就是将原来的入口 MaterialApp 使用 MaterialApp.router 替换了,参数 routerConfig 就是配置的所有的路由页面,比如我这里的配置如下:


final GoRouter _router = GoRouter(routes: <RouteBase>[GoRoute(path: '/',builder: (BuildContext context, GoRouterState state) {return MyHomePage();},routes: <RouteBase>[GoRoute(path: 'two',builder: (BuildContext context, GoRouterState state) {return TwoPage();},),],),],
);

“/” 配置的就是加载的默认的启动的首页面,然后我这里面相当于是配置了两个基本的页面。

2 实现基本的页面交互

在页面MyHomePage放一个按钮,点击按钮打开 TwoPage 第二个页面,打开页面的核心代码如下:
使用 Navigator 正常操作如下“

    Navigator.of(context).push(MaterialPageRoute(builder: (BuildContext context) {return TwoPage();}));

使用 go_router 操作如下:

context.go("/two");

然后在页面 TwoPage 中点击按钮返回上一个页面​:

使用 Navigator 正常操作如下:

 Navigator.of(context).pop();

​用 go_router 操作如下:

context.pop();
3 页面跳转传参数

基本简单参数传递,比如一个 userId,页面路由定义如下:ThreePage就是我定义的目标页面,它需要一个参数 userId。

GoRoute(path: 'three/:userId',builder: (BuildContext context, GoRouterState state) {// 使用 state.params 获取路由参数的值final userId = (state.pathParameters['userId']!);return ThreePage(userId:userId);},),

点击一个按钮跳转目标页面,我这里传的参数 userId的值为 123

context.go("/three/123");

复杂传参数 请看后续

http://www.lryc.cn/news/294026.html

相关文章:

  • QT中,对于大小端UDP网络发送的demo,帧头帧尾
  • ip网络的三类地址及其相互关系
  • 开源计算机视觉库OpenCV详细介绍
  • go消息队列RabbitMQ - 订阅模式-direct
  • PyTorch 2.2 中文官方教程(十八)
  • jenkins部署vue项目
  • 十一、C++核心编程(2)引用
  • numpy学习总结二
  • 3 编辑器(Vim)
  • C/C++ (stdio.h)标准库详解
  • 深度学习介绍
  • ywtool dhcp命令
  • ChatGPT高效提问—基础知识(LM、PLM以及LLM)
  • MongoDB复制集实战及原理分析
  • Java并发之synchronized详解
  • Flask 项目自动生成 API 文档的高效实践
  • WebChat——一个开源的聊天应用
  • 【Linux系统 01】Vim工具
  • Oracle 面试题 | 09.精选Oracle高频面试题
  • 基于Springboot的校园失物招领网站(有报告)。Javaee项目,springboot项目。
  • WPF布局面板
  • 灵活应对:策略模式在软件设计中的应用
  • eosio.token 智能合约介绍
  • 3D 转换
  • AI智能语音机器人安装方法
  • Python 潮流周刊#38:Django + Next.js 构建全栈项目
  • Jenkins升级后,构建任务配置界面重复错位
  • Python基础学习 -07 运算符
  • Nim游戏
  • Pytorch: torch.linspace等间隔数值函数