共计 4361 个字符,预计需要花费 11 分钟才能阅读完成。
作者 / Larry McKenzie
本文由 eBay 技术负责人 Larry Mckenzie 和 Corey Sprague 撰写。您能够收听他们在 Google Apps, Games & Insights 播客 中的探讨,具体理解如何应用 Flutter 构建利用。
构建原生利用原本就不轻松,如果须要在不到一年的工夫内构建出一款利用,同时还要满足指标受众的严格要求,就更加艰难了。咱们在构建 eBay Motors 利用时,就遇到了这样的挑战。但在 Google 的界面工具包 Flutter 的帮忙下,咱们得以疾速针对 Android 和 iOS 平台提供优质且统一的体验。
eBay Motors
过来十几年来,eBay 在汽车市场的业务始终非常沉闷。但在几年前,咱们的领导层发现了一个时机: 咱们能够在 eBay 平台提供定制化的车辆交易服务。购买汽车不同于大多数在线购物: 购车是一项较为重大的生产,而且销售过程中存在一些非凡的问题须要思考。eBay 偏向于上架经典车型、罕见车型、改装车等独特品类的车辆。eBay 卖家往往想要为本人的爱车找到真正懂得观赏和珍惜的买家。很多 eBay 买卖双方都在寻找更加个性化、更为独特的服务,所以咱们想为这些用户构建一款非凡的利用——eBay Motors 利用便应运而生。
指标受众
eBay Motors 的指标受众是宽广汽车爱好者。只管爱好者们每天都会关注汽车,但可能几年才会买一次车。因而,打造一款可能让他们违心定期应用的利用并不容易。开发团队着重钻研了这些人的应用动机,以及他们心愿与其余汽车爱好者互动的形式。
买家可能正在物色下一辆车,或者只是轻易看看或寻找灵感。在思考购买车辆时,买家心愿在决定购买之前充沛获取相干信息。他们心愿可能从各个角度查看车辆 – 内饰、外观、发动机、传动系统。他们想理解车况,也想理解卖家。以后车主的用车状况怎么?他们每天都开车吗?车辆是否在修理厂培修抛光过?车辆是每年行驶一次,只在车展上展出吗?咱们想构建一种能够充沛满足这些需要的体验。
开发团队在与卖家议论发售车辆方面的问题时,发现卖家显著分外关怀买家是谁,而并非总是关怀价格。一些卖家示意,如果他们感觉买家真的会悉心呵护他们的爱车,那么降价出售并非不可承受。这种态度与传统汽车市场天壤之别,在传统汽车市场中,卖家总是心愿可能以最高价格发售车辆。
在考察中,人们认为买卖双方的关系并没有在交易达成后就完结。卖家心愿可能跟踪爱车状况,并持续与他们的买家交换。买家同样心愿保持联系,以便询问: “ 嗨,我想改装这里,但我发现你之前改装过其余部位。能够给我讲讲具体情况吗?” 因而,咱们心愿构建一些性能,使买卖双方造成一个不仅仅只是探讨交易的社区。
抉择 Flutter
在开发这款利用时,eBay Motors 的领导层为开发团队提供了很大的自主权。惟一的要求是: 这款利用必须在一年内实现开发。依据咱们的考察,显然这款利用必须蕴含 eBay 用户所冀望的全副性能: 巨细无遗的商品详情页、拍卖、音讯性能、搜寻等。开发团队还踊跃地增加了有助于造就沉闷社区的性能。这意味着咱们的工作范畴非常庞杂,咱们认为,如果仍然沿用两支独立平台开发团队的模式,将无奈在截止日期前实现工作。
显然,咱们须要一种新的利用开发方法。开发团队之前对跨平台开发工具进行过一些评估,但并没有找到令咱们称心的解决方案。
但在这个我的项目开始时,Flutter 1.0 公布了。Flutter 是 Google 的界面工具包,可基于单个代码库为挪动、网络和桌面端构建富裕吸引力的原生编译利用。这看起来很有前景,所以咱们的开发团队开始了更加具体的考察。
对 Flutter 进行彻底的评估后,开发团队对其相当称心。短短几周内,开发团队便确信 Flutter 是开发这款利用的最佳抉择。
eBay Motors 之前组建了两支开发团队,别离采纳不同的工作形式、工作安顿和编程格调。在决定应用 Flutter 时,必须弄清楚应该如何协调两支开发团队。因为工夫紧迫,因而开发团队在如何构建利用方面必须达成统一。所有人都秉持着雷同的指标 – 打造高品质的产品、疾速交付并超过预期。
两支团队开会讨论了所有一致,只管单方各有退让,但最终后果十分协调,这也为顺利公布产品做好了充分准备。
两支团队都不足 Flutter 和 Dart 的应用教训,但官网提供的指引十分详尽,学习起来非常简单。
首个版本
咱们在 2019 年 3 月收到了第一份产品需要——咱们须要在三个月外向咱们的 CEO 交付蕴含可用交易体验的 Beta 版利用。
第一个版本需要因为工夫缓和,迫使团队大幅削减利用的性能。咱们晓得,即使在 Flutter 的帮忙下,咱们也不可能一次性解决所有问题——无奈构建出蕴含所有交易性能的残缺社区和欠缺的音讯性能。咱们必须制订正当的开发策略,确定须要优先开发的重点性能,而非同时开发所有性能。团队通过探讨削减哪些性能,总结出了大量关注重点。这样咱们就确定了钻研重点,以及随之而来的开发重点。每个渺小变动都会解锁下一个变动,使咱们独特朝着里程碑一步步迈进。咱们踊跃地关注问题,专一地解决用户心愿咱们解决的细节。这一过程艰难且经常凌乱不堪,但在 Flutter 的强力助推下,咱们以意想不到的形式减速追赶上了一个个工作节点。每达到一个节点,团队都会为之振奋。
实现首个里程碑之后,咱们还要攻克多个后续里程碑,而 Flutter 使得咱们可能一次性解决问题,并持续向前迈进。咱们的产品从交付给 CEO 的 Beta 版倒退为 eBay 内测 Beta 版,供数千名 eBay 用户应用。一个月后,咱们的产品进入了公开 Beta 版测试阶段。终于,咱们于 2019 年 12 月底正式公布了 iOS 和 Android 版利用。
对于 eBay Motors 而言,每个时刻都意义不凡。开发团队也通过这些时刻一步步地建设了信念。将产品交付给新用户、取得反馈,并进行更正和调整,咱们堪称 “ 边做边学 ”。朝着指标疾速地交付小规模迭代,也有助于咱们的产品团队取得成功。即便利用的性能和复杂程度一直进步,Flutter 也让咱们可能继续疾速地交付产品。
因为在公布时大幅削减了利用性能,导致此时咱们并没有聊天和社区性能。因而,在 2020 年 1 月,开发团队着手从零开始构建咱们的社区,并在公布后的几个月内减少了 50% 的利用性能。
Flutter 的影响
在刚开始采纳 Flutter 时,咱们只是将其视为一种反对共享代码并节省时间的工程工具。但 Flutter 帮忙开发团队解决了许多咱们并未期待它能解决的问题。在某些状况下,它甚至解决了咱们未知的问题。
咱们心愿确保用户界面在各个平台之间的一致性: 将用户体验重点凝聚在 eBay Motors 品牌上,而非投合特定平台的设计语言。然而,产品必须保留所在平台的具体行为,例如滚动的物理成果以及导航机制。侥幸的是,Flutter 以开箱即用的形式使这些问题迎刃而解。这意味着设计师能够省去很多工作,因为他们只须要制作一份与平台无关的设计即可。
在产品需要方面,咱们心愿平台之间不存在差别。因为每项需要只需实现一次,所以加重了咱们不少的累赘。咱们散会的次数缩小了,事倍功半。
随着开发团队对 Flutter 的理解日益加深,咱们意识到,代码共享堪称意义不凡。在咱们的代码库中,咱们在 Android 和 iOS 之间共享了 98.6% 的代码。只有大概 0.5% 的代码为平台特定的原生代码。其余部分包含咱们的继续集成流水线、自动化工具和开发者反对。
在开发过程中,通过共享代码能够节俭大量资金,而在测试方面也同样如此。在开发团队曾应用过的所有平台当中,Flutter 在测试方面是佼佼者之一。它的测试性能帮忙咱们放慢了进度,并让咱们在公布产品时信心十足。咱们从一开始就采取了强制执行 100% 代码覆盖率的策略,Flutter 让咱们可能轻松实现这一指标。
随着利用进入生产阶段,节俭资金的劣势也在继续体现。因为咱们不用独自解决 iOS 或 Android 谬误,因而反对内容的可预测性要高得多。开发团队能够将新的版本公布到更具包容性的 Android 测试版渠道,之后再充满信心地公布 iOS 版本。因为只需构建和反对一个利用,咱们可能节俭大量资金。
Flutter 入门技巧
如果是初上手 Flutter,在解决挪动利用中的某些问题的时候,必须解脱先入为主的观点,因为 Flutter 所应用的范式与传统 iOS 和 Android 截然不同。当您了解了 Flutter 所用的利用构建形式后,所有都将瓜熟蒂落。最好的学习办法是花些工夫钻研 Flutter 代码库。
Flutter 的一大长处就是开源。您能够查看 Flutter 团队是如何构建每个组件的,从中能够播种很多有价值的信息。
Flutter 社区也十分沉闷。如果您须要 Flutter 框架尚未提供的解决方案,那么很可能曾经有人构建了解决这个问题的 package。咱们激励您的团队摸索并查找所需信息,也欢迎您奉献本人的专业知识并踊跃拥抱开源文化。
Flutter 的前景
在 eBay Motors 刚开始应用 Flutter 时,还鲜有大型公司公开应用该框架: 它过后仅是一款小众工具包,仿佛还不足实战测验。时至今日,这个框架势头愈发强劲,很多公司向其敞开了怀抱。令人兴奋的是,Flutter 提供了最为古代且最为优良的利用开发体验。而最棒的一点是,它仍在一直地倒退与改良。
随着 Flutter 的倒退,Dart 失去了大量的资源投入。Swift 和 Kotlin 中诸如空平安等一些必不可少的个性失去了踊跃的引入。看到 Flutter 的继续倒退,以及这种倒退为构建 Flutter 利用所带来的改良,咱们感到非常喜悦。无论公司体量大小,当大家逐步意识到 Flutter 能够帮忙他们基于单个代码库开发桌面、web 和挪动端利用,天然也会有更多团队采纳 Flutter。
结语
尽管 eBay Motors 开发团队的所有成员都领有原生 iOS 或原生 Android 开发背景,但在用过 Flutter 之后,所有人都不谋而合地喜爱上了它。Flutter 的开发者体验显著好于以往: 它能够利用热重载性能让开发者在进行编码时就取得疾速反馈,而且因为开发流程的顺畅,使得问题可能疾速失去解决,这些都是十分有价值的劣势。在两年的应用过程中,惊喜无处不在。咱们常能听到共事大喊: “ 我爱 Flutter!我刚发现了一个新的妙招!”
对于咱们这样规模的团队,如果没有抉择 Flutter,就没方法实现 eBay Motors 利用的开发。它让咱们可能将资源集中到一起,这是别离构建两个平台利用的模式所无奈实现的。Flutter 是帮忙咱们放慢开发过程的加速器。
更多 Google Play 开发者播客节目,请移步《Apps, Games & Insights 播客节目合辑》,理解不同畛域的开发者通过多种视角与主题,探讨海内市场开发与发行的教训心得。
您对应用 Flutter 构建利用有何想法?欢送在评论区分享您的评论。