使用 Go 和 Web 技术构建桌面应用程序

《开源精选》是我们分享Github、Gitee等开源社区中优质项目的栏目,包括技术、学习、实用与各种有趣的内容。本期推荐的是一个使用 Go 和 Web 技术构建桌面应用程序的项目——WAILS。

c17613f22195bea9a965e3cf517f9ffb.png

Wails 是一个框架,可以使用 Go 和 Web 技术帮助编写桌面应用程序。对于前端,使用 Webview 库. 不过它使用平台的本机渲染引擎(当前 Linux 和 Mac 使用 Webkit,Windows 使用 MSHTML)。前端使用 HTML / Javascript / CSS 编码,后端是纯 Go 语言。通过绑定机制,可以将 Go 代码作为返回 Promise 的功能公开给前端。该项目编译为单个可执行文件,将所有资源捆绑到其中。在 Windows 和 MacOS 上,可以将二进制文件捆绑到特定于平台的程序包中进行分发。

注意:渲染引擎是 WebView,不是捆绑的 Web 浏览器,因此某些“浏览器 API”将对您的应用程序不可用,例如 localstorage。大多数应用程序不需要使用它们,如果您仍然想这样做,可以使用 Go 来完成大多数事情。

功能

  • 后端使用标准 Go

  • 使用任意前端技术构建 UI 界面

  • 快速为您的 Go 应用生成 Vue、Vuetify、React 前端代码

  • 通过简单的绑定命令将 Go 方法暴露到前端

  • 使用原生渲染引擎 - 无嵌入式浏览器

  • 共享事件系统

  • 原生文件系统对话框

  • 强大的命令行工具

  • 跨多个平台

概述

  • Wails

Wails 被设计成尽可能缩小 web 技术和 Go 之间的差异。前端是 Webview 组件, 并且您可以使用自己喜欢的任何常见 Javascript 框架来开发前端代码,并且可以与里面的 Go 代码进行交互。这是通过共享的 IPC 机制来实现的。

a3adacfcdbb2da44ccaf526cea3e2f3d.png
  • IPC 概述

IPC 机制可以在 2 个运行时中运行,一个运行在 Javascript 中,另一个运行在 Go 中。它们都提供了一个简单的接口,从而减轻了开发人员直接处理 IPC 机制的负担。

85c7da9c8822285479be09ff3854fc63.png

运行时共享开发人员可以与之交互的公共组件:绑定和事件。

ade583f43b4d4206b5f4918e70572359.png
  • 绑定

Wails 应用程序提供了一种方法,可让您将公开的 Go 代码(绑定)到前端。使用此方法,可以将任意函数或公开的结构方法绑定。在启动时,Wails 将分析绑定的函数/方法并自动在 Javascript 中提供等效函数。使您可以直接从 Javascript 调用绑定的 Go 代码。

df954a026ae372685982baa37c7fef8a.png

JavaScript 包装函数,处理了调用 Go 代码的所有复杂性。您只需使用 Javascript 调用该函数并接收一个 Promise。绑定 Go 代码功能,处理了绑定的所有复杂性。如果对 Go 代码的调用成功完成,则结果将传递到 resolve 函数。如果返回错误,则将其传递给 reject 函数。

  • 事件

Wails 提供了一个统一的事件系统,类似于 Javascript 的原生事件系统。这意味着从 Go 或 Javascript 发送的任何事件都可以由任何一方接收。数据可以随任何事件一起传递。这样,您就可以做一些简单的事情,例如让后台进程在 Go 中运行,并通知前端去更新页面。

9982b76a645069214d8c71ca142e6ffc.png

安装

  • 安装命令

安装过程非常简单,只需运行以下命令:

go get -u github.com/wailsapp/wails/cmd/wails

安装后,“wails update”命令可用于后续更新。

要获得最新功能的最新 pre-release 可以在后面附加 -pre 标签:wails update -pre.

要完成安装设置,请运行 安装命令 wails setup 并且填写对你的名字和邮箱。

  • 生成新项目

使用初始化命令 wails init 生成一个新项目,选择默认选项。

  • 构建

切换到项目目录 cd my-project 并且使用构建命令构建命令 wails build 构建你的项目。

如果一切顺利,则应该在本地目录中有一个已编译的程序。如果使用 Windows,请使用 ./my-project 来运行它或双击 myproject.exe

2f100dbea6edea9b644cfc12efdab77c.png

项目展示

5223bef9a10e181e8baff2f317f3a68f.png
WOMBAT
2f8edfd2b85ac8924923ad8ddb2d435a.png
SURGE
df6a3d5950746599e837b39ec92ba130.png
MOLLY 钱包
6645d1a1825862d48f1436901f02b6dc.gif
PORTFALL
458c21e064dfb79c655e5970f9f0a092.gif
RESTORIC
30facb9cd9ce108f40391003b8dbc802.png
OPTIMUS 截图编辑器

—END—

开源协议:MIT

开源地址:https://github.com/wailsapp/wails

(点击文末 阅读原文 可直接跳转哦~)

往期推荐

270fa6ae7a88a9a2c6ce042674cc19eb.png

《Go 开源说 2022》预告PAAS系列之第12期 集群镜像技术 sealer

f702a6fb12e401f8ddc6c895a6226ae9.jpeg

基于 QUIC 协议的 HTTP/3 正式发布

d62bc535f93933ab012192020d792761.jpeg

Go高级工程师必修课 | 真心建议你来听听,别错过~

想要了解Go更多内容,欢迎扫描下方👇 关注 公众号,回复关键词 [实战群]  ,就有机会进群和我们进行交流

6955384196b1db67f4188051410f00b3.png

分享、在看与点赞,至少我要拥有一个叭~

b784e18f3f86921225b266c9401956f2.gif

c3ebb687cf3ef9f6ae0fdcd20554fa22.gif

  • 0
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值