Flutter 10: 图解页面小跳转 (二)

简介:       小菜前两天尝试了一下 Flutter 中的页面跳转,主要时通过 Navigator 相关的 push 和 pop 方法进行页面跳转和基本传参,很方便也很简洁;今天小菜补充一下 Flutter 测试过程中常用的另一种页面跳转方式。

      小菜前两天尝试了一下 Flutter 中的页面跳转,主要时通过 Navigator 相关的 pushpop 方法进行页面跳转和基本传参,很方便也很简洁;今天小菜补充一下 Flutter 测试过程中常用的另一种页面跳转方式。

补充一

      小菜上一篇在测试页面跳转时,测试的页面都是在一个 main.dart 文件中;这样自然不合理,按照正常的业务逻辑会有很多分包,这样如何跳转到其他包下或其他文件下的 Page 页面呢?其实很简单,直接引入包名文件即可:

  1. import 包名 + 文件名,小菜测试发现 Flutter 没有像 Android 一样的清单文件,所以需要手动引入包名文件;
  1. 正常调用对应文件中 Page 页面跳转即可;

      Tips: 小菜建议不同文件中不要重名,如果本文件中有与其他包下文件中相同 Page 名称,会优先跳转到本文件中 Page 页。

补充二 fluro

小菜在学习中发现有的大神会用到 fluro,小菜也顺道学习一下,fluro 是 Flutter 关于页面跳转的三方库,它添加了灵活的 options 选项,如通配符、命名参数和清晰的跳转定义。

集成如下:
  1. 在 pubspec.yaml 中添加 fluro 依赖库 fluro: "^1.3.4",如图:
  1. 在需要跳转的页面引入包并初始化定义一个 Router,可以定义全局变量或静态变量,方便在其他地方引用;如图:
import 'package:fluro/fluro.dart';

Router router = new Router();
  1. 初始化之后定义 routes 和 route handlers
var homeHandler = Handler(handlerFunc: (BuildContext context, Map<String, dynamic> params) {
  return HomePage(params["data"][0]);
});

void defineRoutes(Router router) {
  router.define("/home/:data", handler: homeHandler);
}

defineRoutes(router);

Tips: params["data"][0] 中只可传0,否则数组越界。

  1. 调用跳转方式 navigateTo 即可:
onPressed: () {
  // 按 fluro 方式跳转页面并传参
  var bodyJson = {
    'user': (_phonecontroller.text),
    'pass': (_pwdcontroller.text)
  };
//  router.navigateTo(context, "/home/1234", transition: TransitionType.fadeIn);
  router.navigateTo(context, '/home/$bodyJson');
}

Tips: "/home/:data" 中的 data 可以直接传键值对,也可以传递 String/int 等类型的值,可以按需求随意传递;同事 router 也可以向自身传递数据,需添加 transition: TransitionType.fadeIn

      GitHub Demo


      小菜刚接触 Flutter 时间不长,还有很多不清楚和不理解的地方,如果又不对的地方还希望多多指出。以下是小菜公众号,欢迎闲来吐槽~

公众号

目录
相关文章
|
9月前
Flutter Getx 路由 until 方法帮助你跳转指定路由
不少同学都会问我,这样一个场景,当我点击商品列表,进入商品页,点击购买,支付成功后,想返回商品页,或者我的中心的订单列表。怎么做,这中间跨度了 n 个路由。 我不只一次的推荐 GetX 的 until 方法,和 offNamedUntil 方法。 我写了个 demo 今天我们就一起来看下这两个方法如何使用。
725 0
Flutter Getx 路由 until 方法帮助你跳转指定路由
|
3月前
Flutter笔记:使用Flutter构建响应式PC客户端/Web页面-案例
Flutter笔记:使用Flutter构建响应式PC客户端/Web页面-案例
58 0
|
10月前
|
UED 索引
Flutter仿写微信导航栏快速实现页面导航
Flutter仿写微信导航栏快速实现页面导航
|
Android开发
Flutter路由跳转详解
Flutter路由跳转详解
206 0
如何用一行代码实现Flutter页面变灰效果?
如何用一行代码实现Flutter页面变灰效果?
如何用一行代码实现Flutter页面变灰效果?
|
存储 数据安全/隐私保护
Flutter App页面路由及路由拦截实现
直接使用页面跳转会带来诸多缺陷,通过路由管理可以降低页面耦合,提高代码的可维护性和权限控制。本篇介绍了 Flutter 的路由管理和拦截实现。
1139 1
Flutter App页面路由及路由拦截实现
|
JSON 数据格式 容器
Flutter 仿微信价值几个亿的页面
网传微信支付页面的第三方链接一个格子需要广告费1一个亿,微信支付页非常适合做功能导航,本篇使用 ListView和 GridView 模仿微信支付页面
222 0
Flutter 仿微信价值几个亿的页面
|
存储 索引 容器
Flutter 构建常用的 App 页面框架
详细讲解如何用 Flutter 构建一个底部导航的 App 页面框架
424 0
Flutter  构建常用的 App 页面框架
Flutter 跳转并关闭当前页面
Flutter 跳转并关闭当前页面
1445 0