两天时间,用 Flutter 写出一个股票分析客户端

为什么要用 Flutter

用户体验与原生一致:2017 年 Google 发布 Flutter 到今天已经 3 年多了。它与其他跨平台框架最大的不同是可以直接编译成原生应用。这使得应用的体积接近原生应用,性能也几乎与原生应用一致。

缩短开发时间:随着 3 年多的发展,Flutter 生态日趋完善,并已在淘宝闲鱼知乎等大型客户端上使用。随着 2.0 版本发布,Flutter 已经可以满足电商,社交,直播,企业办公等众多商业场景的业务需要。同时,一次开发多端发布,提升了研发效率,使业务功能可以在 Android 和 iOS 平台同时上线

面向未来支持全平台:除了 Android 和 iOS 之外,Flutter 也可以在 MacOS,Linux 和 Windows 上运行。面向 5G 时代,Google 开源的物联网操作系统 Fuchsia 也默认支持 Flutter 应用。未来搭载 Fuchsia 系统的智能穿戴,智能家居,智能园区,车载系统等物联网设备上都可以直接运行Flutter应用。

时至今日,Flutter 已经具备了诸多优势,并可以帮助企业快速将服务交付给用户

基于以上原因,我选择了 Flutter 作为客户端技术。用一个小而全的应用来梳理 Flutter 在移动应用开发中的优势和不足。

一个小而全的客户端

验证一项技术最直接的方法就是用它做一个原型项目。对于前端应用来说需要优先验证以下几个方面:

  • UI / UX 绘制的方式和效率
  • 数据,业务逻辑和 UI 组件的解耦方式
  • UI 组件库的定制化程度
  • 架构模式
  • 性能,兼容性,稳定性
  • 单元测试
  • 开发工具成熟度
  • 可调试性
  • 线上日志采集方式

股票分析客户端主要从后台服务获取数据,进行处理并在页面中绘制图表。功能不多,但可以验证以上需要验证的方面。

客户端主要包括以下功能:

投资模型列表(数据加载):


分析模型列表

投资模型模拟投资(Flutter 图表):


模拟投资

投资模型模拟投资(Web 图表):


DeMark

股票详情(Web 网页):


详情展示

优势与不足

优势

UI / UX 绘制的方式和效率

声明式 UI 描述效率高:熟悉 Web 开发或 Swift 开发的工程师可以很容易上手。同时因为 UI 绘制完全有 Flutter 自身完成,不依赖于平台组件,可以做到 Android 和 iOS 一致。我在开发时使用 iPhone 模拟器,打包发布到 Android 手机上界面与 iPhone 模拟器效果完全一样,极大的节省了双平台调试和适配的时间

数据,业务逻辑和 UI 组件的解耦

原生支持解耦 :StatelessWidget 与 StatusfulWidget 的概念,可以很好的解耦 UI 组件与业务组件。同时 Class 为一等公民的概念,使应用开发面向对象,可以做到高内聚低耦合

UI 组件库的定制化程度

原生组件持平:Material 组件库提供了主题定制能力,同时 UI 组件的可配置参数也非常丰富。可以从主题的纬度,组件的纬度进行定制。

性能,兼容性,稳定性

发布包体积小:APP 打包后体积仅 18MB,这让我非常惊喜。相对于 RN 动辄 30MB+ 起步的体积,确实有很大提升。
性能逼近原生:100多数据的列表加载无延迟;1500+节点的图表动画切换平滑无卡顿。从用户体验角度,性能已接近原生水平。业界评测机构给出的结果:相对于原生 Flutter 性能消耗为1.2倍,而 RN 是15倍。
UI / UX 兼容性良好:iPhone 模拟器环境开发后可以直接发布到 Android 手机进行测试。组件自适应不同屏幕尺寸无需开发时适配。

开发工具成熟度

开发工具完备:Flutter 提供的命令行工具和 IDE 插件可以完整支撑 APP 开发的全生命周期。同时,编辑器插件可以帮助开发人员快速重构代码,提升代码质量。

不足

架构模式

缺少标准架构模式:像 RN 和 Vue 等UI框架一样,作为一款主要针对 UI 的框架,在业务逻辑和数据层管理层面没有提出明确方案。目前业界主流的单向数据流模型响应式模型都相应的 Flutter 版本,但缺少一套完善的 Framework 来保证项目长期开发过程中架构不会腐化。这需要 Flutter 项目的架构师在启动项目之前,定义好合适的模型,制定项目开发规范,与开发团队达成共识,并将代码质量检查机制落实到流水线和质量门禁工具中

一些原生开源 UI 组件未适配

缺少开源 UI 组件:在开发股票图表时,主流的开源图表库均未适配 Flutter 平台。建议在项目开始前,由架构师充分评估需要用到的UI组件。对于没有相应开源组件的功能,做好充分的评估,并预留足够的开发时间。

可调试性如何

错误提示不够明确:Flutter 的热重载功能给开发带来极大的效率提升。这个特性对 Web 工程师来说早已习惯,并没有太多惊喜。反而是含糊的类型错误提示,有时让人不知所措。

声明式 UI 嵌套过深造成语法错误:在 RN 中,声明式 UI 使用的是类似 HTML 的方式,tag 标签方式可以快速定位未闭合元素。而 Flutter 使用 “()”方式进行闭包,导致一旦出现未匹配情况,很难快速定位,往往需要花很长时间进行调整。

线上日志采集

目前业界缺少健全的日志收集方式。架构师应在项目启动阶段根据项目定义采集纬度和指标,确保线上运行情况可感知

待验证项目

时间原因,单元测试没有在本次开发中验证,待验证后补充。

总结

Flutter 作为跨平台 UI 框架,不仅可以在 Android ,iOS, Web 和 PC 上使用,更面向为未来 5G 时代的 IoT 设备设计。可以解决 5G 时代企业临的在“多尺寸屏幕”和“低性能”的 IoT 设备上研发应用的问题。

同时,一次开发多平台发布的特性也极大的提升了交付效率。这使企业可以用更短的时间将服务提供终端用户,提升企业自身的行业竞争力

无论现在还是未来,都建议企业研发团队引入 Flutter 作为移动端开发技术,来提升业务交付效率。

后记:两天时间都做了些什么工作

第一天

3小时:根据 Flutter 中文网说明安装环境。因为网络问题,无法直接使用官网服务。大多数时间用来寻找和配置国内网络镜像。这里推荐清华大学的镜像源。排除网络问题后,顺利安装并初始化项目。Flutter 提供的命令行工具包括初始化,包管理,调试运行,构建等应用全生命周期支持,熟悉命令行工具的工程师可以非常高效的通过命令行完成应用开发所需要的工作。

30分钟:初始化 Flutter 项目,并在 GitHub 创建代码仓。与后端约定使用 GitHub Issue 功能进行 bug 修复和新功能开发等简单项目管理工作。

1小时:通过 Learn Dart in Y mins 学习 Dart。因为我本身对 Javascript 和 Typescript 有所了解,所以没有太多认知上的障碍,一边看一边写就好了。

1小时:了解 Flutter 的组件基本概念和 StatefulWidget 和 StatelessWidget 的用途。简单的说:纯 UI 组件用 StatelessWidget;有业务逻辑的用 StatefulWidget。这是内置的 UI 与业务解耦的约定。这个设计很有优势,从框架级别就划分好 UI 组件与业务组件,从根源避免 UI 与业务耦合。

4 小时:开发业务功能,大部分时间都用来在熟悉 Material 的组件接口和在社区搜索相应的组件。其中用到最多的是布局组件列表组件。Flutter 的热重载技术可以在代码修改后,直接在模拟器中看到效果,避免像原生应用开发那样再次编译。这个特性极大的提高了开发效率和体验。但 Flutter 的错误提示稍有不足,特别是类型错误时,只提示类型不兼容,让人不知所措。

1小时:根据官方文档打包发布。主要时间花费在为 Android 创建和配置密钥,以及修改包名。打包好后通过蒲公英测试平台发布。注:蒲公英被微信屏蔽,需要在浏览器内打开。

第二天

4 小时:寻找合适的图表组件。遇到 Flutter 生态不完善的老问题,像 Web 端和 Native 端的知名图表库 EChart 或者 HighChart 都没有对应的 Flutter 版本。这里有三个替代方案:

  1. 使用基础 Flutter UI 组件开发
  2. 使用简单的图表组件满足最小业务需要
  3. 使用 WebView 嵌入 EChart 或 HighChart

在我的应用中,在“模型模拟”页面分别尝试了“使用简单组件满足最小业务需求”和“ WebView 嵌入”两种方式。

  • “简单组件”使用 Flutter 的方式绘制原生界面,交互更平滑,性能更高。这种方式可以做到毫秒级绘制1500+节点到图表,动画无卡顿。
  • “WebView 嵌入”方式加载慢,但功能强大。一次开发 Web 与 APP 都可以使用,后期通过直接嵌入本地静态 H5 资源,只加载数据的方式,可以提升明显加载速度。

2 小时:调整其他页面接口,抽象UI组件。 这里要介绍一下 VSCode 的 Flutter 插件,提供了丰富的重构功能。它可以快速的将混在 StatefulWidget 中的通用 UI 组件抽象成 StatelessWidget ,极大提升了重构效率。

image.png

6 小时:整理这篇文章。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,015评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,262评论 1 292
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,727评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,986评论 0 205
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,363评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,610评论 1 219
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,871评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,582评论 0 198
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,297评论 1 242
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,551评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,053评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,385评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,035评论 3 236
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,079评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,841评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,648评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,550评论 2 270

推荐阅读更多精彩内容