做者 / Larry McKenzieweb
本文由 eBay 技术负责人 Larry Mckenzie 和 Corey Sprague 撰写。您能够收听他们在 Google Apps, Games & Insights 播客 中的讨论,详细了解如何使用 Flutter 构建应用。
构建原生应用原本就不轻松,若是须要在不到一年的时间内构建出一款应用,同时还要知足目标受众的严格要求,就更加困难了。咱们在构建 eBay Motors 应用时,就遇到了这样的挑战。但在 Google 的界面工具包 Flutter 的帮助下,咱们得以快速针对 Android 和 iOS 平台提供优质且一致的体验。编程
过去十几年来,eBay 在汽车市场的业务一直十分活跃。但在几年前,咱们的领导层发现了一个机遇: 咱们能够在 eBay 平台提供定制化的车辆买卖服务。购买汽车不一样于大多数在线购物: 购车是一项较为重大的消费,并且销售过程当中存在一些特殊的问题须要考虑。eBay 倾向于上架经典车型、稀有车型、改装车等独特品类的车辆。eBay卖家每每想要为本身的爱车找到真正懂得欣赏和珍惜的买家。不少 eBay 买卖双方都在寻找更加个性化、更为独特的服务,因此咱们想为这些用户构建一款特殊的应用——eBay Motors 应用便应运而生。安全
eBay Motors 的目标受众是广大汽车爱好者。尽管爱好者们天天都会关注汽车,但可能几年才会买一次车。所以,打造一款可以让他们愿意按期使用的应用并不容易。开发团队着重研究了这些人的使用动机,以及他们但愿与其余汽车爱好者互动的方式。网络
买家可能正在物色下一辆车,或者只是随便看看或寻找灵感。在考虑购买车辆时,买家但愿在决定购买以前充分获取相关信息。他们但愿可以从各个角度查看车辆 - 内饰、外观、发动机、传动系统。他们想了解车况,也想了解卖家。当前车主的用车状况怎样?他们天天都开车吗?车辆是否在修理厂维修抛光过?车辆是每一年行驶一次,只在车展上展出吗?咱们想构建一种能够充分知足这些需求的体验。框架
开发团队在与卖家谈论出售车辆方面的问题时,发现卖家明显格外关心买家是谁,而并不是老是关心价格。一些卖家表示,若是他们以为买家真的会悉心呵护他们的爱车,那么降价出售并不是不可接受。这种态度与传统汽车市场截然不同,在传统汽车市场中,卖家老是但愿可以以最高价格出售车辆。工具
在调查中,人们认为买卖双方的关系并无在交易达成后就结束。卖家但愿可以跟踪爱车状况,并继续与他们的买家交流。买家一样但愿保持联系,以便询问: "嗨,我想改装这里,但我发现你以前改装过其余部位。能够给我讲讲具体状况吗?" 所以,咱们但愿构建一些功能,使买卖双方造成一个不只仅只是讨论交易的社区。学习
在开发这款应用时,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 帮助开发团队解决了许多咱们并未期待它能解决的问题。在某些状况下,它甚至解决了咱们未知的问题。
咱们但愿确保用户界面在各个平台之间的一致性: 将用户体验重点凝聚在 eBay Motors 品牌上,而非迎合特定平台的设计语言。可是,产品必须保留所在平台的具体行为,例如滚动的物理效果以及导航机制。幸运的是,Flutter 以开箱即用的方式使这些问题迎刃而解。这意味着设计师能够省去不少工做,由于他们只须要制做一份与平台无关的设计便可。
在产品需求方面,咱们但愿平台之间不存在差别。因为每项需求只需实现一次,因此减轻了咱们很多的负担。咱们开会的次数减小了,事半功倍。
随着开发团队对 Flutter 的了解日益加深,咱们意识到,代码共享可谓意义非凡。在咱们的代码库中,咱们在 Android 和 iOS 之间共享了 98.6% 的代码。只有大约 0.5% 的代码为平台特定的原生代码。其他部分包括咱们的持续集成流水线、自动化工具和开发者支持。
在开发过程当中,经过共享代码能够节省大量资金,而在测试方面也一样如此。在开发团队曾使用过的全部平台当中,Flutter 在测试方面是佼佼者之一。它的测试功能帮助咱们加快了进度,并让咱们在发布产品时信心十足。咱们从一开始就采起了强制执行 100% 代码覆盖率的策略,Flutter 让咱们可以轻松实现这一目标。
随着应用进入生产阶段,节省资金的优点也在持续体现。因为咱们没必要单独处理 iOS 或 Android 错误,所以支持内容的可预测性要高得多。开发团队能够将新的版本发布到更具包容性的 Android 测试版渠道,以后再充满信心地发布 iOS 版本。因为只需构建和支持一个应用,咱们可以节省大量资金。
若是是初上手 Flutter,在解决移动应用中的某些问题的时候,必须摆脱先入为主的观念,由于 Flutter 所使用的范式与传统 iOS 和 Android 大相径庭。当您理解了 Flutter 所用的应用构建方式后,一切都将水到渠成。最好的学习方法是花些时间研究 Flutter 代码库。
Flutter 的一大优势就是开源。您能够查看 Flutter 团队是如何构建每一个组件的,从中能够收获不少有价值的信息。
Flutter 社区也很是活跃。若是您须要 Flutter 框架还没有提供的解决方案,那么极可能已经有人构建了解决这个问题的 package。咱们鼓励您的团队探索并查找所需信息,也欢迎您贡献本身的专业知识并积极拥抱开源文化。
在 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 构建应用有何想法?欢迎在评论区分享您的评论。