让Golang在桌面端起飞,盘点使用Wails开发优势与不足

Wails作为一个使用Golang开发跨平台桌面端的框架,几乎是目前Gopher唯一的选择,当然也有其他框架可选,但是个人感觉都不太成熟。本人使用Wails开发Tiny RDM不知不觉已有半年,现就这段接触使用时间来做个大概总结分享。

优点

1. 打包包体极小

由于并不包含浏览器运行时,所以包体随便能到10M以下。但并不意味着内存占用小,和附带浏览器的electron类应用相比,实际运行起来内存占用半斤八两,毕竟本质都是web应用套壳。

2. 开发体验接近Web全栈开发

如果你是个gopher,又刚好会写点前端网页,那wails会是你很好的选择,开发时也能直接浏览器运行,即改即刷新,开发些小工具速度一流。

3. 前后端自动绑定

只要Go中声明要导出的结构体实例,写好接口方法,就能自动生成JavaScript方法声明,直接调用即可,无论是Go端的结构体,还是JavaScript端的数组/对象,都能比较友好地进行转换。而且还有基于通知的双端通讯实现,方便进行频繁的数据传输。

4. 可自定义资源服务

这也是基于Web的App一个好处,通过自定义资源路径来决定本地资源读取路径,甚至是读取远程资源文件,可以以此为基础实现资源热更新。

缺点

1. 兼容性一般

这个electron类应用的优势就体现出来了,毕竟不同平台上的浏览器内核或多或少都会有差异。有时会遇到一个正常的写法在Windows和macOS上运行得好好的,在Linux上就错位了,这让我想起了IE6/7/8/9时代的噩梦。比如在一些旧版本的系统上(有用户反馈win10也会),甚至会出现整个页面都是白屏或者不显示,这相关的几个issue目前还躺在那等着大牛来处理~相信随着时间的推移,和新老版本操作系统的更替,这些不兼容性的问题会逐渐消失,基于Webview开发的应用也会越来越多。

2. 运行效率一般

由于前后端语言不一致,一些复杂的逻辑和数据操作也通常会使用Go来处理,处理完成后需要发送给前端进行展示,中间涉及到前后端通讯就会有所消耗。而且Web前端处理能力上限不高,所以瓶颈往往也在这。在一些比较复杂的界面,比如树形列表,进行一次大量的增删操作,往往需要拆分多次来处理,拆分后每次处理的量实际也不好把控,数量多了容易导应用假死,数量少了一个完整的操作就需要耗费更多等待时间。

3. 系统级的接口不够

同为基于Webview的Tauri相对会好一些,但这个还是比electron差太多了。比如我想监听主窗口的尺寸和位置变化,并实时保存变化后的值方便下次启动应用时恢复,也只能依靠些奇技淫巧来解决(新开个goroutinue来定时获取和判断窗口是否有变化)。像比较常用的多窗口支持和系统上下文菜单等等,wails目前也是缺失的。

4. 打包工具不完善

虽然通过wails cli就能打包,但是整体体验还是差强人意,Windows和macOS上还算够用,但Linux上就不太舒服了。目前Tiny RDM打包使用的是Github Action,配置文件部分参考了另一个使用wails的开源项目october并做了自定义修改。目前Tiny RDM仅支持deb安装包,但是Linux版本众多,依赖的Webview也各不相同,所以deb有时都不能做到即装即用,还要安装Webview运行时等等(这个问题在旧版的Windows上也有)。其中呼声最高的appimage格式,目前我也暂时无能为力。

5. 不支持导出Web端

这个和上一点说的有些重复,单独作为一点是因为它本身就是基于Web开发的应用,大部分人应该都默认它原生支持Web模式了,但实际上却不支持导出Web版本,这多少还是有点说不过去。目前开发模式下可以直接通过浏览器运行和调试前端,但也仅限于开发模式下了。并且包括一些系统接口也不支持Web端的,如打开对话框选择文件,Web模式下打开的却是在App端的系统文件选择对话框。不过真正麻烦的应该是Go后端逻辑没法在浏览器运行,相信随着Golang的Webassembly逐步成熟,后续官方会支持起来的。

6. 没有原生自更新

上面优点中提到了它的资源管理器可以方便热更新,但是仅限于前端页面,涉及到Go编写更改的部分,仍然是需要重新安装的。在快速版本迭代的现今,自更新可以减少用户使用新版本的障碍,目前自更新wails官方也加入到了roadmap中#1178,相信不久将来这个反而变成它的优点了。

7. 插件市场不丰富

wails目前没有官方的插件市场,也就只能依靠丰富的Web插件和不太丰富的Golang第三方依赖了。但比较尴尬的是,NPM上也只能使用纯前端插件,而Go的依赖大多数是为了服务后端的,服务于操作系统的不多,比如Tiny RDM中用到的第三方依赖userdir,用于获取本机中用户数据目录的,最后一次更新是9年前了;再比如其中用到的获取系统字体的第三方依赖sysfont也无法完整拿到系统内建字体列表。所以即使前后端语言都有生态市场,但都挺难用于wails上。


以上仅仅是个人的观点和使用感受,不代表一个框架一定得有个高低优劣之分。我个人最终的结论是:基于Webview的应用目前还是不太适合用来开发商业应用,但是很适合想快速做一些小工具的。当然它随着开发者使用者增加,也日趋完善,还有roadmap中计划支持Android和iOS都是比较令人期待的。

使用Wails的正经开源项目不多,最后附上本人开源项目Tiny RDM,这是一个跨平台的Redis桌面客户端,轻量美观易用,功能齐备(基本和市面上的客户端齐平),既有颜又能打。也可为打算使用Wails开发的小伙伴用作参考,代码工整,也有必要注释(都是英文注释,因为后续打算让老外也用上国人开发的软件,我们也能做出优秀的作品)。如果这个项目对你所有帮助,给我点个star就是对我最大的支持了~


Tiny RDM 软件界面

官网地址:https://redis.tinycraft.cc/zh/
源码地址:https://github.com/tiny-craft/tiny-rdm

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

推荐阅读更多精彩内容