不知为何,我的跨平台Web应用实际上更稳定。我想,我浪费了大量时间开发原生iOS应用。 这一切要从我想做一款可以帮助父母们安排孩子上学的App开始。 我是一个有3个孩子的父亲。在工作中,有很多功能强大的工具可以帮我组织和管理团队,但在家里却没有任何工具可以帮我安排孩子们去上学,每次都搞得一团糟,为此我感到很恼火。于是我想,为什么不给孩子们列一个待办事项清单呢?我可以让它的使用体验看起来像游戏一样,甚至嵌入游戏化的设计元素,帮助孩子们保持专注和参与度。 所以我开发了SchoolMorningRoutine,效果非常棒。现在,孩子们准备上学的时间缩短为原来的30,我们唠叨的时间也减少了95(是的,我算过了)。 但在开发过程中,我犯了一个大错误。我浪费了大量时间开发原生iOS应用。为什么最开始我选择了原生开发 在2022年,要开始一个移动App项目,最大的问题在于有很多完全不同的技术方向可供你选择:原生应用、跨平台Web应用、ReactNative、Flutter、渐进式Web应用、Xamarin等等。 默认的方案是写3次代码,一次针对iOS,一次针对Android,一次针对Web。 但是,对我们软件开发人员来说,多次编写相同的代码是非常令人不安和不自然的。因此,这么多年来,我们已经尝试了几十种方法,试图实现一次编写,到处运行,但它们都涉及令人讨厌的权衡。 如果选择了跨平台Web应用,你只需要使用通用的Web技术编写代码,然后将其部署到多个平台上,只是有少量涉及iOS和Android功能的原生代码无法在浏览器中运行。 但你需要在性能方面做出权衡。 2014年,我尝试用IonicFramework开发一款不同的应用,然后我和大多数人都发现了统一的问题:Android和iOS运行Web应用的表现很糟糕。 它们响应慢、行为不可预测、断断续续、忽隐忽现,触屏互动体验也很古怪。 所以,我很早就确定SchoolMorningRoutine不应该是一款跨平台Web应用。这款应用将大量使用游戏风格的动画,因为它是面向儿童的,所以它需要出色的触屏互动体验。 不知为何,我的跨平台Web应用实际上更稳定 所以,我决定开发一款原生应用。原生应用通常风险最小、质量最高。当然,同样的应用做了两次,这不是什么好事,但它毕竟是一款小应用,我相信努力比魔法更重要。 首先,我做了一款漂亮的iOS应用,并与测试用户进行了多次迭代。然后我将其发布到AppStore上,并获得了一些用户反馈。除了收到五星好评,还有来自用户的电子邮件。用户在邮件里说这款应用是如何改变了他们的生活和工作。 我很高兴自己取得了一些成绩,并决定接下来要开发Web应用。我使用了React,再加上CSS动画、Framer和一些Lottie动画。在开发完成后,我花了一下午仔细调优性能,只是想确保没有做不必要的渲染。 那时,我的孩子们已经使用iOS原生版SchoolMorningRoutine好几周了。为了测试这个新的跨平台Web版本,我把它装到孩子的iPad上。他们可以用它来测试,为上学做准备。 有趣的是,我忘记告诉他们那个App已经从原生改为Web版了,但第二天早上他们却没有注意到。 他们没有注意到。 他们甚至都没有注意到。 如果你没有孩子,可能就不会意识到这个。要知道,孩子总是抱怨所有的东西。真的,所有的东西。但是,当第二天我问他们是否注意到有什么不同时,他们不仅没有抱怨那款Web版App,还感谢我,因为我在Web版中使用了不同的动画,他们当中有两个更喜欢它。 他们是对的,新版的动画流畅如黄油,触屏互动体验更加精准。 我感到很震惊。也许只是因为iPad的性能好?于是,我出去买了一台低端的Android平板电脑。我选择了一款功能配置差的,即使是打开设置屏幕都很不流畅。但这也是一项重要的测试,因为对许多人来说,这是他们唯一能使用的设备。 我加载了SchoolMorningRoutine,你猜怎么着,它运行得很好。虽然不算很出色,但这只是一款低端的Android平板电脑,你还能期待什么? 于是,我走到办公桌前,删除了我的原生iOS应用,决定使用IonicCapacitor。 现在,我要开发一款可以在三个平台上运行的App。我的构建脚本中有3个命令,分别用于部署到iOS平台、Android平台或AWS的网站上。 这太酷了! 从那时起,我便在Android、iOS和Web上发布SchoolMorningRoutine。不仅我的iOS用户没有注意到,漏洞的数量也减少了。有一个麻烦的Bug与渲染表格视图有关,这个问题只发生在iOS14上,它打印出来的堆栈跟踪信息没有用但在我的跨平台Web应用中,就不存在这个问题。 直线出现在跨平台Web应用发布之后 不知为何,我的跨平台Web应用实际上更稳定!这是怎么回事? 为儿童开发的一款到处都是动画的App居然是一款Web应用,这怎么可能? 事实证明,在2022年,对于许多应用程序来说,编写一次就可以在任何地方运行的梦想终于实现了。 对于跨平台Web应用来说,成本和收益之间的权衡总是以较差的性能换取较短的开发时间。对于2014年的大多数应用来说,这是一个糟糕的权衡。但在过去的8年里,很多事情都发生了变化。浏览器性能在稳步提升: 图片来源:https:v8。devblog10years Web应用开发工具的种类和成熟度也在增加。现在,我们有了React和TypeScript。IDE和Chrome调试器比原生应用开发工具要领先好几光年。有很多创新的设计模式和开源库可用于实现你能想到的目标。JavaScript的世界比Swift或Kotlin的世界更加有活力和丰富多彩。 2022年,成本和收益之间的权衡发生了变化。 跨平台Web应用的时代正在到来 我一直是Ionic的铁粉。他们在几年前创办了一家公司,是跨平台Web应用的早期倡导者。我喜欢他们所做的工作,但我一直为他们感到难过。他们似乎押错马了,支撑跨平台Web应用的技术无法支撑他们的梦想。 但到了今天,我认为技术的发展终于与Ionic的愿景合拍了。 可能你在几年前就疯狂地想要开发一款像SchoolMorningRoutine这样的跨平台Web应用。这确实没毛病!它很漂亮,真的!我已经在谷歌PlayStore和苹果AppStore上发布了这款应用,你甚至可以在线使用它。 不只是我,JoshWardle在去年末开发了Wordle,这款手机游戏现在正风靡全球。正如我在另一篇文章(https:uxdesign。ccwordleisamasterclassinproductdesignsimplicity52de1ba06d85)中所写的,它甚至都没有原生版本,只是一个使用Web组件开发的渐进式Web应用。结论 我多么希望在我开始开发SchoolMorningRoutine时能够读到这样的文章。过去,我忽视了跨平台Web应用,只因为我觉得它们太慢了,但没想到它们却完美匹配我的应用。 浏览器和Web技术每年都在变得越来越强大,每年都有更多类型的应用可以跨平台开发。 所以,在开始下一个项目之前,为什么不考虑一下跨平台Web应用呢?或许它们真的不适你的项目,但或许,就像我一样,你会发现它们可以编写一次,到处运行。我觉得这非常出人意料。 如果你想了解跨平台技术在国内的最新实践,点击GMTC全球大前端技术大会(北京站)发现Weex2。0、Waft(基于WebAssembly和Skia的IoT应用开发框架),还将看到KMM、DSL的优秀表现。 原文链接(本文对文章结构有小小的改动):https:javascript。plainenglish。ioireplacedmynativeiosappwithacrossplatformwebappandnoonenoticed1653901ce244