flutter图片点击跳转_Flutter 09: 图解页面小跳转 (二)

本文介绍了在Flutter中进行页面跳转的两种方式:通过Navigator的push和pop方法,以及使用Fluro库进行更灵活的页面路由。详细讲解了如何在不同文件和包之间进行跳转,以及Fluro的集成和使用,包括定义路由、传递参数和页面过渡效果。
摘要由CSDN通过智能技术生成

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

补充一

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

正常调用对应文件中 Page 页面跳转即可;

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

补充二 fluro

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

集成如下:在 pubspec.yaml 中添加 fluro 依赖库 fluro: "^1.3.4",如图:

在需要跳转的页面引入包并初始化定义一个 Router,可以定义全局变量或静态变量,方便在其他地方引用;如图:import 'package:fluro/fluro.dart';

Router router = new Router();

初始化之后定义 routes 和 route handlersvar homeHandler = Handler(handlerFunc: (BuildContext context, Map params) {  return HomePage(params["data"][0]);

});void defineRoutes(Router router) {

router.define("/home/:data", handler: homeHandler);

}

defineRoutes(router);

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

调用跳转方式 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。

小菜刚接触 Flutter 时间不长,还有很多不清楚和不理解的地方,如果又不对的地方还希望多多指出。

作者:阿策神奇

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值