第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定

Flutter 09: 圖解頁(yè)面小跳轉(zhuǎn) (二)

標(biāo)簽:
Android

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

webp

补充一

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

  1. import 包名 + 文件名,小菜测试发现 Flutter 没有像 Android 一样的清单文件,所以需要手动引入包名文件;

webp

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

webp

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

补充二 fluro

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

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

webp

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

import 'package:fluro/fluro.dart';

Router router = new Router();

webp

  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,否则数组越界。

webp

  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

webp


      GitHub Demo


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



作者:阿策神奇


點(diǎn)擊查看更多內(nèi)容
TA 點(diǎn)贊

若覺得本文不錯(cuò),就分享一下吧!

評(píng)論

作者其他優(yōu)質(zhì)文章

正在加載中
移動(dòng)開發(fā)工程師
手記
粉絲
168
獲贊與收藏
165

關(guān)注作者,訂閱最新文章

閱讀免費(fèi)教程

  • 推薦
  • 評(píng)論
  • 收藏
  • 共同學(xué)習(xí),寫下你的評(píng)論
感謝您的支持,我會(huì)繼續(xù)努力的~
掃碼打賞,你說多少就多少
贊賞金額會(huì)直接到老師賬戶
支付方式
打開微信掃一掃,即可進(jìn)行掃碼打賞哦
今天注冊(cè)有機(jī)會(huì)得

100積分直接送

付費(fèi)專欄免費(fèi)學(xué)

大額優(yōu)惠券免費(fèi)領(lǐng)

立即參與 放棄機(jī)會(huì)
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)

舉報(bào)

0/150
提交
取消