点击围观!腾讯 TAPD 助力金融行业研发提效、敏捷转型最佳实践! 了解详情
写点什么

Electron 开发指南:前端人的最佳跨平台解决方案 | 极客时间

  • 2020-01-09
  • 本文字数:2036 字

    阅读完需:约 7 分钟

Electron 开发指南:前端人的最佳跨平台解决方案 | 极客时间


作为一个跨平台的桌面应用开发框架,Electron 的迷人之处在于,它是建立在 Chromium 和 Node.js 之上的 —— 二位分工明确,一个负责界面,一个负责背后的逻辑。也不难理解,为什么 Electron 能开发跨平台的桌面应用了。


但是,不同系统间还是会有很大的差异,需要相应地做一些额外处理,使得打包出的应用在不同系统下都能正常运转。但相比于 80% 都能完全复用的代码,这些成本几乎可以忽略不计。



所以,对 Web 前端开发者来说,用 Electron 开发多平台客户端的成本非常低


而且,Electron 是基于 Node.js 的,这就意味着,Node 这个大生态下的模块,Electron 都可以用。同时,跨平台也让 Electron 可同时开发 Web 应用和桌面应用,无论是 UI,还是代码,很多资源都可以共享,大幅减少了开发者的工作量


作为目前非常热门的技术,Electron 在 GitHub 上已经有 7w+ star 了,很多应用都是用 Electron 开发的,比如字节跳动的飞书、Slack、VS Code、Atom、Skype、WhatsApp、支付宝小程序 IDE(蚂蚁开发者工具)等。



与此同时,包括蚂蚁金服、小米、华为、GitHub、微软在内的很多大厂都在使用 Electron。因此,学好 Electron 是你日后跳槽加薪的加分项,毕竟,大厂都在用。

如何深入理解,并高效使用 Electron?

Electron 写一个简单的桌面端应用并不难,有一定 JavaScript 基础的话,可能只要半小时。但要做一个项目,就没那么容易了:


第一,涉及技能栈众多。我们不仅要了解 Electron、客户端知识,还要在客户端中使用 Node.js,甚至是集成 C++、Rust 等三方库,涉及多进程等概念,对基础薄弱的前端工程师来说有些难度。


第二,基建缺乏,工程化建设难以落地。Electron 基建在大部分公司都比较缺乏,依赖 Web、手机客户端的基建无法满足 Electron 业务,比如在 Mac 端打包可以依赖 iOS 持续集成,但 Windows 端则不行,类似场景非常之多。


第三,欠缺充分利用好 Electron 的能力。在开发 Electron 应用时,很多 Web 前端工程师会习惯性地局限于浏览器开发思维中,做出的交互和体验与 Web 应用一样,不知如何释放自己的想象力,并发挥客户端的作用。


其实,以上这些问题,我都遇到过。我所负责的美团大象,早在 2016 年就开始用 Electron 技术构建桌面端了,是美团最早一批用 Electron 做大型项目的团队。


那会儿,我们从 0 开始探索 Electron 的工程化建设,从组内小 Demo 到全公司的桌面客户端,搭建了 Electron 更新、崩溃治理、异常监控等多项基础服务。凭借这些实战经验,我帮很多兄弟团队实现了 Electron 技术从无到有的落地过程。


当然,在这期间,我们也遇到了很多问题。在解决问题的过程中,我经常思考:如何让 Web 前端同学在工程中快速开发、最大程度地发挥 Electron 的作用,为业务带来更好的体验,创造更大的价值。


所以,我和极客时间合作了视频课《Electron 开发实战》。在课程中,我会带你完整开发一个桌面远程控制项目,还会针对 Electron 的工程化建设进行具体讲解,指出有哪些技术关键点,和需要避开的坑,帮你彻底拿下 Electron。

我是谁

我是邓耀龙,美团高级前端工程师,负责美团企业办公平台大象桌面端的工作。除业务支撑外,还负责公司内的 Electron 桌面应用基础建设,致力于提升桌面端开发的交付效率和交付质量。曾受邀参加 2019 年 QCon 大会,做了名为《Electron 在企业 IM 前端工程实践》的主题演讲。


我所负责的美团大象,是美团最早使用 Electron 做大型项目的团队,早在 2016 年就开始用 Electron 构建桌面端,从 0 开始搭建了 Electorn 更新、崩溃治理、异常监控等多个基础服务。

我是如何讲解 Electron 的?

我是以 Web 前端工程师的视角设计这门课的,相比市面上的其他 Electron 资料,这门课主要有 2 个特点:


1.偏实战,让你在项目中熟悉 Electron 的技术特点并感受其乐趣。


2.重工程化,为你梳理在工作中推行 Electron 工程化的建设思路,讲述真实项目中遇到的坑和具体的解决方案。


所以,课程并不仅仅局限于 Electron 本身,更多讲解与其相关的工程化建设流程,侧重于提升你的整体开发能力。


而且,Electron 是使用 Web 技术开发桌面应用的,可以考虑将 Web 应用与桌面应用作为同一个应用来开发,可以大大提升开发效率。


课程分 3 个部分:

第一部分为基础篇,介绍 Electron 并深挖其原理,与 Web 开发做对比,针对不同之处介绍 Electron 开发。让你在实战中巩固基础,并带你写出一个 Demo。


第二部分为项目实战篇,带你从 0 开始,完成一个桌面控制软件——这是一个结合 Electron、Node.js 和 WebRTC 技术的综合项目。


第三部分为工程篇,我会逐步完善实战篇的项目,为你讲解在真实项目中做 Electron 应用的流程、工程化建设的关键点和实践技巧,帮你在业务中顺利落地。


现在订阅有什么福利?

1.早鸟优惠 ¥68,原价 ¥99。结算时,输入优惠口令「electron6」再减 5 元,到手仅 63 元,口令仅限【前 200 个】名额有效。


订阅后生成分享海报,每成功邀请 1 位好友订阅,可得 ¥24 返现


优惠口令仅限【 前 200 个名额 】有效。👉 戳此使用,以最低价 ¥63 订阅。


2020-01-09 11:305076

评论

发布
暂无评论
发现更多内容
Electron 开发指南:前端人的最佳跨平台解决方案 | 极客时间_前端_邓耀龙_InfoQ精选文章