Flutter——另类设计,提升页面开发效率,简化跳转以及传值

伊始

前几日一位大佬考我,说:

flutter页面开发需要写StatefulWidget和State,Android只需要Activity,
如何简化这种开发方式?

我答曰:

activity还需要写xml呢~

在大佬的静默中,四周浮现起热烈的掌声......

......

深夜,天桥下的我辗转反侧、难以入眠......

‘ 难道,真的可以? ’......

经过反复推敲打磨后,这个‘轮子’还确实有点儿圆,‘滚’起来还挺顺溜。

天桥之下难免简陋,如有不足还请海涵,万望指点~ 嘿嘿 
构思

我们一般开发页面A,结构如下:

class A extends StatefulWidget{
}

class AState extends State<A>{
}

同时为了解耦和对路由统一做控制,我们采取的页面跳转方式(即静态路由)是:

Navigator.of(context).pushName('/a')

此种跳转方式的缺点就是页面传值需要map形式,不方便的同时,还容易输错Key,就算使用注解依然无法避免。

反复观察和思考得出了下面这样一张结构图

结构图

对各模块做一下简单介绍

BaseState

abstract class BaseState<T extends StatefulWidget> extends State<T>{}

对page和view通用功能的封装

WidgetState

abstract class WidgetState extends BaseState with WidgetGenerator{}

对自定义view的通用功能封装

PageState

abstract class PageState extends BaseState with WidgetGenerator,RouteAware{}

对自定义Page的通用功能封装

RouteAware对路由观测,你可以埋点或者记录等等

WidgetGenerator

mixin WidgetGenerator on BaseState implements _RouteGenerator,_NavigateActor{}

生成widget并为widget装配功能

_RouteGenerator 生成Route(可带过渡动画)功能

  PageRoute<T> buildRoute<T>(Widget page, String routeName, {PageAnimation animation, Object args}) {
                ....
  }

_NavigateActor 路由的各种push和pop操作,你也可以拓展

  Future push<T extends PageState>(T page,{PageAnimation animation});
  Future pushAndRemoveUntil<T extends PageState>(T page,{PageAnimation animation,RoutePredicate predicate});
  Future pushReplacement<T extends Object,TO extends PageState>(TO page, {PageAnimation animation, T result });

  void pop<T extends Object>({T result,});
  void popUntil({RoutePredicate predicate});

  bool canPop();

各模块就介绍完毕了,下面介绍一下使用方法。

如何使用

页面的开发

当我们需要开发页面A时,如下:

clas A extends PageState{
   Widget build(BuildContext context){...}
}

就这么简单。

页面传值

当我们想向B页面传一个值/返回一个值到A页面时,如下:

clas B extends PageState{
    final var value;
    B(this.value);

   Widget build(BuildContext context){...}
}

A跳到B
A页面内:push(B('你的值'))
            .then((value)=>'B返回值=$value');

B退到A
B页面内:pop(result:'返回给A的值');

pushAndRemoveUntil的使用

如果我从A到B到C,然后C到D页面的时候我想移除B和C,操作如下:

在C页面

push(D(),predicate: (route)=>route.settings.name == '$A')

D页面

当你pop()后,你会发现到了A页面

生成widget

我并不需要跳转,但是需要将我的页面/View生成widget,操作如下:

你的页面/View.generateWidget({Key key}) 就可以生成一个widget了
如果需要key,还可以加上一个
最后

我已经将框架内的Demo置换为现有的开发方式,同时新增加了针对性的Demo并进行了反复的测试,总体来说确实大幅度提升了开发效率,避免了key值出错的问题,另外在替换过程中也没有遇到兼容性问题,

不过这个依然算是初版。

大家可以在下面的框架中使用,看看有啥不足或者bug告诉我,非常感谢。

Bedrock框架

Bedrock开发框架

原文链接:juejin.im

上一篇:Taro跨端开发之让Taro UI支持React Native
下一篇:浅析鸿蒙 JavaScript GUI 技术栈

相关推荐

  • 高频数据交换下Flutter与ReactNative的对比

    (标题图片来自网络,侵删) 后端使用go写的socketio服务模拟期货行情数据,每10ms推送10条行情数据 ReactNative已经尽力优化了。 Flutter由于没flutter-socket...

    2 年前
  • 首发 | 闲鱼公开多年 Flutter 实践经验

    阿里妹导读:Flutter从诞生到现在,已经成为了跨端开发的领跑者。闲鱼应用在flutter能够以模块形式存在前,进行了很长时间的混合app架构的探索,对原生工程进行较多改动,在官方推出flutte...

    1 年前
  • 页面跳转的归纳

    前端工作有很多地方需要页面跳转,有很多种实现方法,这里做一下归纳。 HTML标签 一般形式上可以用&lt;a&gt;&lt;/a&gt;、&lt;button&gt;&lt;/button&gt;、&...

    3 年前
  • 页面跳转时,点击上报丢失问题解析

    背景 最近在工作中,遇到了页面跳转时点击上报丢失的问题,突出表现在微信ios的webview上,上报后直接跳转的失败率达到了惊人的93%。喝口水压压惊,开始逐步分析问题的发生。

    3 年前
  • 页面跳转中的安全问题

    最近参与了一小部分安全排查,涉及到一些前端编码安全问题,记个小tip。 1.Http请求头中的Referer 上图是一个http请求的header,其中referer字段就是当前的页面地址,那么这个...

    10 个月前
  • 页面之间传值之url传值-实现点击携参跳转到详情页

    概念图 实现功能: 电影列表页,数据为动态获取服务器数据,点击某个电影后跳转到电影详情页,数据为根据点击的参数去服务器请求对应数据回来填充到页面显示给用户 效果图 电影列表页 电影详情页 思路及...

    2 年前
  • 闲鱼基于Flutter的移动端跨平台应用实践

    作者|王树彬编辑|覃云本文来自阿里巴巴闲鱼无线技术专家王树彬在今年 GMTC 大会上的演讲。闲鱼为什么使用 Flutter Flutter 作为 Google 新一代的跨平台框架,有较多的优点,但跟其...

    2 年前
  • 路由页面跳转后状态保存实践

    “路由页面跳转后状态保存”指的是在开发业务需求过程中经常会碰到的一种情况——在一个页面(通常是表格页)进行一顿猛如虎的操作之后,点击某一项详情进入另外一个页面之后再返回(点击后退按钮),上一页还可以保...

    6 个月前
  • 让前端开发者失业的技术,Flutter Web初体验

    Flutter是一种新型的“客户端”技术。它的最终目标是替代包含几乎所有平台的开发:iOS,Android,Web,桌面;做到了一次编写,多处运行。掌握Flutter web可能是Web前端开发者翻...

    1 年前
  • 解决因ios弹性机制或者浏览器顶部导航栏fixed进行页面跳转 导致页面内容被遮挡或者页面新页面滚动位置不对

    const scrollToTop = () =&gt; {   if (!isAndroidApp) {     window.scrollTo(0, 0);     const inp = doc...

    4 个月前

官方社区

扫码加入 JavaScript 社区