当前位置: 首页 > news >正文

Go Wails 学习笔记:创建第一个项目

文章目录

      • 1. 安装 Wails
      • 2. 创建 Wails 项目
      • 3. 项目结构
      • 4. 运行项目
      • 5. 构建项目
      • 6. 部署和发布
      • 总结

Wails 是一个用于构建跨平台桌面应用程序的框架,允许开发者使用前端技术(如 HTML、CSS、JavaScript)以及 Go 语言来开发桌面应用。本文基于官方文档《 Wails 入门指南 - 创建第一个项目》总结 Wails 的项目创建过程。

1. 安装 Wails

在开始使用 Wails 之前,你需要在系统中安装它。按照文档的说明,使用以下命令安装 Wails:

go install github.com/wailsapp/wails/v2/cmd/wails@latest

确保你已经安装了 Go 语言,并将其添加到环境变量中。安装完成后,可以通过运行以下命令验证 Wails 是否成功安装:

wails doctor
git:(feat-wails) ✗ wails docker
Wails CLI v2.9.2Available commands:build      Builds the application dev        Runs the application in development mode doctor     Diagnose your environment init       Initialises a new Wails project update     Update the Wails CLI show       Shows various information generate   Code Generation Tools version    The Wails CLI version Flags:-helpGet help on the 'wails' command.

此命令将检查系统的依赖环境,并确保一切正常运行。

2. 创建 Wails 项目

创建项目的过程相当简单,只需运行以下命令即可:(PS: 最新版本需要-n参数指定项目名)

wails init -n wails-demo

这会启动一个交互式的 CLI 提示,你可以选择项目的类型。通常有两种模板供选择:

  1. Vue 模板:适合那些喜欢使用 Vue.js 构建前端的开发者。
  2. React 模板:适合那些习惯于使用 React 的开发者。

选择其中一种模板并输入项目名称后,Wails 会自动生成一个包含前端和后端代码的基本项目结构。

框架项目指定TypeScript
sveltewails init -n myproject -t sveltewails init -n myproject -t svelte-ts
reactwails init -n myproject -t reactwails init -n myproject -t react-ts
vuewails init -n myproject -t vuewails init -n myproject -t vue-ts
preactwails init -n myproject -t preactwails init -n myproject -t preact-ts
litwails init -n myproject -t litwails init -n myproject -t lit-ts
vanillawails init -n myproject -t vanillawails init -n myproject -t vanilla-ts

3. 项目结构

.
├── build/
│   ├── appicon.png
│   ├── darwin/
│   └── windows/
├── frontend/
├── go.mod
├── go.sum
├── main.go
└── wails.json

项目生成后,主要目录结构如下:

  • frontend/:前端代码,通常使用你选择的框架(Vue/React)来编写。
  • go.mod:Go 项目的模块定义文件。
  • main.go:主要的 Go 语言入口文件,负责管理应用的后端逻辑。
  • wails.json:Wails 项目的配置文件。

这个结构清晰地将前端和后端分离,使得开发者能够分别处理界面和逻辑部分。

frontend 目录没有特定于 Wails 的内容,可以是您选择的任何前端项目。

build 目录在构建过程中使用。 这些文件可以修改以自定义您的构建。 如果从 build 目录中删除文件,将重新生成默认版本。

go.mod 中的默认模块名称是“changeme”。 您应该将其更改为更合适的内容。

4. 运行项目

项目初始化完成后,可以通过以下命令运行项目:

wails dev

这个命令会启动开发服务器,并在默认浏览器中打开应用。在开发过程中,任何前端代码的修改都会被自动编译和更新,方便实时预览效果。

该程序执行以下操作:

- 构建您的应用程序并运行它
- 将您的 Go 代码绑定到前端,以便可以从 JavaScript 调用它
- 使用 Vite 的强大功能,将监视您的 Go 文件中的修改并在更改时重新构建/重新运行
- 启动一个 网络服务器 通过浏览器为您的应用程序提供服务。 这使您可以使用自己喜欢的浏览器扩展。 你甚至可以从控制台调用你的 Go 代码。
标志描述默认
-appargs “参数”以 shell 样式传递给应用程序的参数
-assetdir “./path/to/assets”从给定目录提供资产,而不是使用提供的资产 FSwails.json 中的值
-browser在启动时打开浏览器到 http://localhost:34115
-compiler “编译器”使用不同的 go 编译器来构建,例如 go1.15beta1go
-debounce检测到资产更改后等待重新加载的时间100 (毫秒)
-devserver “host:port”将 wails 开发服务器绑定到的地址“localhost:34115”
-extensions触发重新构建的扩展(逗号分隔)go
-forcebuild强制构建应用程序
-frontenddevserverurl “url”使用 3rd 方开发服务器 url 提供资产,例如:Vite“”
-ldflags “标志”传递给编译器的额外 ldflags
-loglevel “日志级别”要使用的日志级别 - Trace, Debug, Info, Warning, ErrorDebug(调试)
-nocolour关闭彩色命令行输出false
-noreload资产更改时禁用自动重新加载
-nosyncgomod不同步 go.mod 中的 Wails 版本false
-race使用 Go 的竞态检测器构建false
-reloaddirs触发重新加载的附加目录(逗号分隔)wails.json 中的值
-s跳过前端构建false
-save将指定的 assetdirreloaddirswailsjsdirdebouncedevserverfrontenddevserverurl 标志的值保存到 wails.json 以成为后续调用的默认值。
-skipbindings跳过 bindings 生成
-tags “额外标签”传递给编译器的构建标签(引号和空格分隔)
-v详细级别 (0 - silent, 1 - standard, 2 - verbose)1
-wailsjsdir生成生成的Wails JS模块的目录wails.json 中的值
示例:wails dev -assetdir ./frontend/dist -wailsjsdir ./frontend/src -browser此命令将执行以下操作:构建应用程序并运行它(更多细节在 这里)
在 ./frontend/src 中生成 Wails JS 模块
监听 ./frontend/dist 中文件的更新并在更改时重新加载
打开浏览器并连接到应用程序

5. 构建项目

开发完成后,你可以通过以下命令构建桌面应用:

wails build

这个命令会生成适用于目标操作系统的可执行文件。生成的文件可以直接分发和安装,无需用户单独安装任何依赖。

标志描述默认
-clean清理 build/bin 目录
-compiler “编译器”使用不同的 go 编译器来构建,例如 go1.15beta1go
-debugRetains debug information in the application and shows the debug console. 允许在应用程序窗口中使用 devtools
-devtoolsAllows the use of the devtools in the application window in production (when -debug is not used). Ctrl/Cmd+Shift+F12 may be used to open the devtools window. NOTE: This option will make your application FAIL Mac appstore guidelines. Use for debugging only.
-dryrun打印构建命令但不执行它
-f强制构建应用
-garbleargs传递给 garble 的参数-literals -tiny -seed=random
-ldflags “标志”传递给编译器的额外 ldflags
-m编译前跳过 mod tidy
-nopackage不打包应用程序
-nocolour在输出中禁用颜色
-nosyncgomod不同步 go.mod 中的 Wails 版本
-nsis为 Windows 生成 NSIS 安装程序
-o 文件名输出文件名
-obfuscated使用 garble 混淆应用程序
-platform为指定的 平台(逗号分割)构建,例如: windows/arm64windows/arm64。 注意,如果不给出架构,则使用 runtime.GOARCH如果给定环境变量 platform = GOOS 否则等于 runtime.GOOS。 如果给定环境变量 arch = GOARCH 否则等于 runtime.GOARCH.
-race使用 Go 的竞态检测器构建
-s跳过前端构建
-skipbindings跳过 bindings 生成
-tags “额外标签”构建标签以传递给 Go 编译器。 必须引用。 空格或逗号(但不能同时使用)分隔
-trimpath从生成的可执行文件中删除所有文件系统路径。
-u更新项目的 go.mod 以使用与 CLI 相同版本的 Wails
-upx使用 “upx” 压缩最终二进制文件
-upxflags传递给 upx 的标志
-v int详细级别 (0 - silent, 1 - default, 2 - verbose)1
-webview2WebView2 安装策略:download,embed,browser,error.download
-windowsconsole保留Windows构建控制台窗口
示例:wails build -clean -o myproject.exe信息
在 Mac 上,应用程序将被绑定到 Info.plist,而不是 Info.dev.plist。苹果芯片上的 UPX
在苹果芯片上使用 UPX 相关的 问题。Windows 上的 UPX
一些防病毒软件供应商误将 upx 压缩的二进制文件标记为病毒,请查看相关 问题。

6. 部署和发布

构建完成的应用可以直接发布。根据操作系统的不同,你可以打包成可安装文件(如 Windows 的 .exe,MacOS 的 .dmg 等)。文档还提供了一些打包工具的建议,如 electron-builder,方便对应用进行进一步的包装和签名。

支持的平台有:

平台描述
darwinMacOS + architecture of build machine
darwin/amd64MacOS 10.13+ AMD64
darwin/arm64MacOS 11.0+ ARM64
darwin/universalMacOS AMD64+ARM64 universal application
windowsWindows 10/11 + architecture of build machine
windows/amd64Windows 10/11 AMD64
windows/arm64Windows 10/11 ARM64
linuxLinux + architecture of build machine
linux/amd64Linux AMD64
linux/arm64Linux ARM64

总结

Wails 通过结合前端技术和 Go 后端,提供了一个高效的方式来开发跨平台的桌面应用。其简单的项目初始化和清晰的结构使得开发者能够快速上手。通过 Wails,可以充分利用 Web 开发技能,同时获得原生桌面应用的优势。

相关文章:

Go Wails 学习笔记:创建第一个项目

文章目录 1. 安装 Wails2. 创建 Wails 项目3. 项目结构4. 运行项目5. 构建项目6. 部署和发布总结 Wails 是一个用于构建跨平台桌面应用程序的框架,允许开发者使用前端技术(如 HTML、CSS、JavaScript)以及 Go 语言来开发桌面应用。本文基于官方…...

Postman使用-基础篇

前言 本教程将结合业界广为推崇和使用的RestAPI设计典范Github API,详细介绍Postman接口测试工具的使用方法和实战技巧。 在开始这个教程之前,先聊一下为什么接口测试在现软件行业如此重要? 为什么我们要学习Postman? 现代软件…...

LeetCode 202.快乐数

LeetCode 202.快乐数 C 思路: 用快慢指针来进行解答,可以将其看做一个回环链表,慢指针完成一次平方和操作,快指针完成两次平方和操作,当快慢指针相遇时,判断快慢指针是否为1(为1以后无论怎么取平方和都会为…...

Redis-03 持久化(RDB, AOF,混合持久化)及原理

1,持久化 Redis的持久化是必须的,当Redis服务宕机后,如果没有持久化,重启服务后redis中的数据都将丢失,所有的数据操作都将直连数据库,系统性能会大幅降低,所以在使用Redis做缓存服务时必须持久…...

TikTok账号策略:IP和网络环境的要求分析

在当今社交媒体迅猛发展的时代,TikTok作为一款短视频平台,凭借其独特的算法和庞大的用户基础,吸引了越来越多的内容创作者和营销人员。成功地运营一个TikTok账号,除了优质的内容创作外,良好的IP和网络环境也至关重要。…...

vue后台管理系统从0到1(5)

文章目录 vue后台管理系统从0到1(5)完善侧边栏修改bug渲染header导航栏 vue后台管理系统从0到1(5) 接上一期,我们需要完善我们的侧边狼 完善侧边栏 我们在 element 组件中可以看见,这一个侧边栏是符合我们…...

OpenAI的新功能Canvas,效果还不错

时隔两年,ChatGPT终迎来界面全新升级! 这一次,OpenAI官宣推出类似 Anthropic 的 Artifacts 的界面交互功能 canvas,并称这是一种使用 ChatGPT 写作和编程的新方式。不论是写作,还是编码,都可以开启全新的交…...

了解一些常用的Javascript对象方法

javascript 的对象包含许多有用的方法,可以帮助开发人员轻松操作对象。让我们通过简短的解释和示例来了解一些最重要的内容 object.create()object.assign()object.keys()object.values()object.entries()object.freeze()object.seal()object.preventextensions()o…...

【知识科普】GraphQL一个强大的API查询语言

文章目录 概述📚 GraphQL 的类型系统是如何工作的?🔍 能否举例说明 GraphQL 的类型系统在实际应用中是如何工作的?位置步骤 1: 定义类型步骤 2: 实现解析器步骤 3: 客户端查询步骤 4: 执行查询 🛠️ 在实际开发中&…...

Spring Boot 整合达梦

Maven 依赖 <dependency><groupId>com.dameng</groupId><artifactId>DmJdbcDriver18</artifactId><version>8.1.2.192</version></dependency> yml配置 datasource:master:url: jdbc:dm://192.168.211.113:30236username: WE…...

Vue.js 组件开发基本步骤

Vue.js 是一个构建用户界面的渐进式框架&#xff0c;它被设计为能够轻松地被集成进项目的部分功能&#xff0c;或者用于构建完整的前端应用。组件化是 Vue.js 的核心概念之一&#xff0c;它允许开发者将界面拆分成独立、可复用的组件&#xff0c;每个组件负责应用中的一小部分功…...

博客搭建之路:hexo使用next主题渲染流程图

文章目录 hexo使用next主题渲染流程图 hexo使用next主题渲染流程图 hexo版本5.0.2 npm版本6.14.7 next版本7.8.0 next主题的配置文件中搜索找到mermaid&#xff0c;把enable配置改为true mermaid:enable: true# Available themes: default | dark | forest | neutraltheme: de…...

【数据结构与算法】线性表顺序存储结构

文章目录 一.顺序表的存储结构定义1.1定义1.2 图示1.3结构代码*C语言的内存动态分配 二.顺序表基本运算*参数传递2.1建立2.2初始化(InitList(&L))2.3销毁(DestroyList(&L))2.4判断线性表是否为空表(ListEmpty(L))2.5求线性表的长度(ListLength(L))2.6输出线性表(DispLi…...

Unix Standardization and Implementations

Unix标准化 在Unix未制定较为完备的标准时&#xff0c;各个平台的系统调用方式各异&#xff0c;所开发出的应用程序存在可移植性差的特点&#xff0c;因此人们呼吁指定一套Unix标准来规范接口&#xff0c;增加应用程序的可移植性。所谓Unix标准即适用于Unix环境下的一系列函数…...

Windows 与 Java 环境下的 Redis 利用分析

1 前言 在最近的一次攻防演练中&#xff0c;遇到了两个未授权访问的 Redis 实例。起初以为可以直接利用&#xff0c;但后来发现竟然是Windows Java (Tomcat)。因为网上没有看到相关的利用文章&#xff0c;所以在经过摸索&#xff0c;成功解决之后决定简单写一写。 本文介绍了…...

机器视觉系统硬件组成之工业相机篇

工业相机是一种非常重要的机器视觉器件&#xff0c;它能够将被采集的图像信息通过电路转换成电信号&#xff0c;再通过模数转换器&#xff08;ADC&#xff09;将其转化为数字信号&#xff0c;最后以标准的视频信号输出。工业相机在机器视觉领域得到了广泛应用&#xff0c;包括质…...

离线安装bitnami-gitlab8.8.4+汉化

注意&#xff1a; 常规安装gitlab需要联网&#xff0c;而按装bitnami-gitlab无需联网(bitnami-gitlab用于内网环境无法联网时安装gitlab&#xff0c;两者是一个东西只是名字不一样)bitnami-gitlab-8.8.4版本可以汉化成功新用户注册账户无需激活也可以直接登录&#xff0c;因为…...

亚马逊日本站推出AI日语listing功能,Listing一键发布,轻松无忧!

随着大数据与人工智能技术的成熟&#xff0c;AI在电商的应用也越来越多&#xff0c;各大电商平台都在陆续引进AI人工智能&#xff0c;有客服方面的&#xff0c;也有发布Listing方面的。 10月17日消息&#xff0c;亚马逊日本站近日宣布推出一项支持日语的人工智能listing功能&am…...

Golang | Leetcode Golang题解之第475题供暖器

题目&#xff1a; 题解&#xff1a; func findRadius(houses, heaters []int) (ans int) {sort.Ints(houses)sort.Ints(heaters)j : 0for _, house : range houses {dis : abs(house - heaters[j])for j1 < len(heaters) && abs(house-heaters[j]) > abs(house-…...

【Vue】Vue3.0 (十二)、watchEffect 和watch的区别及使用

上篇文章&#xff1a; 【Vue】Vue3.0 &#xff08;十二&#xff09;、watch对ref定义的基本类型、对象类型&#xff1b;reactive定义的对象类型的监视使用 &#x1f3e1;作者主页&#xff1a;点击&#xff01; &#x1f916;Vue专栏&#xff1a;点击&#xff01; ⏰️创作时间&…...

Linux硬盘分区管理

硬盘分区管理 大容量的硬盘&#xff0c;分区使用&#xff1a;C盘系统盘&#xff0c;D盘办公&#xff0c;E盘娱乐。 类似于&#xff1a;买了一个房子100平方&#xff0c;隔断&#xff1a;主卧、次卧1、次卧2、厨房、卫生间。识别硬盘设备接口类型设备命名示例说明SATA/SAS/USB/S…...

【2026 最新】JDK 下载与安装:在 macOS 下使用 Homebrew 和 jenv 完美管理多版本 JDK

结合 Homebrew 和 jenv 是在 macOS 上管理多版本 JDK 的最佳实践。Homebrew 负责安装具体的 JDK 文件&#xff0c;而 jenv 负责在这些版本之间灵活切换。 Homebrew安装配置看下面的教程&#xff1a; 【2026 最新】Mac 终端神器 Homebrew 完全指南&#xff1a;从安装、换源加速…...

Qwen3-ASR-0.6B快速入门:无需复杂配置,开箱即用体验

Qwen3-ASR-0.6B快速入门&#xff1a;无需复杂配置&#xff0c;开箱即用体验 想试试语音转文字&#xff0c;但被复杂的模型部署和配置劝退&#xff1f;今天给你介绍一个“傻瓜式”的语音识别工具——Qwen3-ASR-0.6B。它最大的特点就是简单&#xff0c;你不需要懂深度学习&#…...

AI净界RMBG-1.4使用技巧:让抠图效果更完美的几个小方法

AI净界RMBG-1.4使用技巧&#xff1a;让抠图效果更完美的几个小方法 1. 为什么抠图效果有时不够理想&#xff1f; 即使是目前最先进的RMBG-1.4模型&#xff0c;在某些特殊情况下也可能出现边缘不够完美的情况。这通常不是模型本身的问题&#xff0c;而是由于输入图片的特性导致…...

解决Vivado中FDCP时序警告的实战技巧

1. 理解FDCP时序警告的本质 在Vivado开发过程中遇到FDCP时序警告时&#xff0c;很多开发者第一反应是"这又是个莫名其妙的警告"。但根据我处理过的二十多个类似案例&#xff0c;这个警告其实是个非常负责的"哨兵"&#xff0c;它在提醒你电路可能存在严重的…...

为什么 Multi-Agent 比单 Agent 更难

为什么 Multi-Agent 比单 Agent 更难——从协作黑洞到协同效率巅峰的全维度拆解 (全文预计42万字) 一、 引言:从 ChatGPT 的“天花板对话”到 AgentVerse 的“分布式协作故障”——这才是 AI 应用落地的真实门槛 1.1 钩子(The Hook):单Agent vs Multi-Agent 的两个真实…...

告别“权限不足”:手把手教你用CobaltStrike的Bypass UAC功能搞定Windows提权

实战指南&#xff1a;利用CobaltStrike突破Windows权限限制 当你手握一个普通用户权限的Beacon会话&#xff0c;却卡在"请求的操作需要提升"的提示前&#xff0c;这种挫败感每个渗透测试员都深有体会。Windows的用户账户控制(UAC)就像一堵无形的墙&#xff0c;将普通…...

基于STM32的智能录音机设计与实现

1. 项目概述这个基于STM32的录音机项目是我最近完成的一个嵌入式系统设计实践。作为一个经常需要记录会议和灵感的人&#xff0c;我一直对市面上的录音设备不太满意——要么功能单一&#xff0c;要么价格昂贵。于是决定自己动手&#xff0c;用STM32F103C8T6作为主控&#xff0c…...

WS2812嵌入式驱动:高精度时序与柔性硬件协同设计

1. WS2812驱动库深度解析&#xff1a;面向智能LED夹克的嵌入式底层实现1.1 技术定位与工程需求溯源WS2812并非一个抽象的“库”&#xff0c;而是一类集成控制电路与RGB LED于一体的智能发光单元。其核心价值在于将传统LED驱动中复杂的时序控制、电平转换、电流调节等模拟电路功…...

Cross Q: Enhancing Deep Reinforcement Learning with Batch Normalization and Wide Critic Networks for

1. 深度强化学习的样本效率困境 深度强化学习&#xff08;Deep Reinforcement Learning, DRL&#xff09;近年来在游戏AI、机器人控制等领域取得了显著进展&#xff0c;但样本效率&#xff08;Sample Efficiency&#xff09;问题始终是制约其实际应用的瓶颈。简单来说&#xff…...