跳到內容

建置系統

Wails 提供統一的建置系統,它會編譯 Go 程式碼、封裝前端資源、將所有內容嵌入單一可執行檔,並處理平台特定的建置——只需一個指令即可完成。

Terminal window
wails3 build

輸出: 內含所有內容的原生可執行檔。

[建置流程圖表佔位符]

Wails 掃描您的 Go 程式碼以了解您的服務:

type GreetService struct {
prefix string
}
func (g *GreetService) Greet(name string) string {
return g.prefix + name + "!"
}

Wails 提取的內容:

  • 服務名稱:GreetService
  • 方法名稱:Greet
  • 參數類型:string
  • 返回類型:string

用途: 生成 TypeScript 綁定

Wails 生成類型安全的綁定:

frontend/bindings/GreetService.ts
export function Greet(name: string): Promise<string> {
return window.wails.Call('GreetService.Greet', name)
}

優點:

  • 完整的類型安全
  • IDE 自動完成
  • 編譯時錯誤檢查
  • JSDoc 註解

您的前端打包工具會執行(Vite、webpack 等):

Terminal window
# Vite 範例
vite build --outDir dist

發生什麼事:

  • JavaScript/TypeScript 被編譯
  • CSS 被處理並壓縮
  • 資源被最佳化
  • 產生原始碼對應(僅開發環境)
  • 輸出到 frontend/dist/

Go 程式碼會以最佳化方式編譯:

Terminal window
go build -ldflags="-s -w" -o myapp.exe

旗標:

  • -s:移除符號表
  • -w:移除 DWARF 除錯資訊
  • 結果:更小的二進位檔(減少約 30%)

平台特定:

  • Windows:嵌入圖示的 .exe
  • macOS:.app 套件結構
  • Linux:ELF 二進位檔

前端資源被嵌入到 Go 二進位檔中:

//go:embed frontend/dist
var assets embed.FS

結果: 單一可執行檔,所有內容都在內部。

單一原生二進位檔:

  • Windows:myapp.exe(約 15MB)
  • macOS:myapp.app(約 15MB)
  • Linux:myapp(約 15MB)

無需依賴(除了系統 WebView)。

針對速度最佳化:

Terminal window
wails3 dev

發生什麼事:

  1. 啟動前端開發伺服器(Vite 在 port 5173 上)
  2. 編譯未最佳化的 Go 程式碼
  3. 啟動應用程式並指向開發伺服器
  4. 啟用熱重載
  5. 包含原始碼對應

特性:

  • 快速重建(前端變更少於 1 秒)
  • 不嵌入資源(從開發伺服器提供)
  • 包含除錯符號
  • 啟用原始碼對應
  • 詳細日誌記錄

檔案大小: 較大(包含除錯符號約 50MB)

Terminal window
wails3 build

輸出: build/bin/myapp[.exe]

Terminal window
# 為 Windows 建置(從任何作業系統)
wails3 build -platform windows/amd64
# 為 macOS 建置
wails3 build -platform darwin/amd64
wails3 build -platform darwin/arm64
# 為 Linux 建置
wails3 build -platform linux/amd64

交叉編譯: 從任何平台為任何平台建置。

Terminal window
# 自訂輸出目錄
wails3 build -o ./dist/myapp
# 跳過前端建置(使用現有的)
wails3 build -skipbindings
# 乾淨建置(移除快取)
wails3 build -clean
# 詳細輸出
wails3 build -v
Terminal window
# 除錯建置(包含符號)
wails3 build -debug
# 生產建置(預設,已最佳化)
wails3 build
# 開發建置(快速,未最佳化)
wails3 build -devbuild

Wails 使用 Taskfile 進行建置設定:

Taskfile.yml
version: '3'
tasks:
build:
desc: 建置應用程式
cmds:
- wails3 build
build:windows:
desc: 為 Windows 建置
cmds:
- wails3 build -platform windows/amd64
build:macos:
desc: 為 macOS 建置(通用)
cmds:
- wails3 build -platform darwin/amd64
- wails3 build -platform darwin/arm64
- lipo -create -output build/bin/myapp.app build/bin/myapp-amd64.app build/bin/myapp-arm64.app
build:linux:
desc: 為 Linux 建置
cmds:
- wails3 build -platform linux/amd64

執行任務:

Terminal window
task build:windows
task build:macos
task build:linux

建立 build/build.json 以進行持久化設定:

{
"name": "My Application",
"version": "1.0.0",
"author": "Your Name",
"description": "Application description",
"icon": "build/appicon.png",
"outputFilename": "myapp",
"platforms": ["windows/amd64", "darwin/amd64", "linux/amd64"],
"frontend": {
"dir": "./frontend",
"install": "npm install",
"build": "npm run build",
"dev": "npm run dev"
},
"go": {
"ldflags": "-s -w -X main.version={{.Version}}"
}
}

Wails 使用 Go 的 embed 套件:

package main
import (
"embed"
"github.com/wailsapp/wails/v3/pkg/application"
)
//go:embed frontend/dist
var assets embed.FS
func main() {
app := application.New(application.Options{
Name: "My App",
Assets: application.AssetOptions{
Handler: application.AssetFileServerFS(assets),
},
})
app.Window.New()
app.Run()
}

在建置時:

  1. 前端建置到 frontend/dist/
  2. //go:embed 指令包含檔案
  3. 檔案編譯進二進位檔
  4. 二進位檔包含所有內容

在執行時:

  1. 應用程式啟動
  2. 資源從記憶體提供
  3. 資源無需磁碟 I/O
  4. 載入速度快

嵌入其他檔案:

//go:embed frontend/dist
var frontendAssets embed.FS
//go:embed data/*.json
var dataAssets embed.FS
//go:embed templates/*.html
var templateAssets embed.FS

Vite(預設):

vite.config.js
export default {
build: {
minify: 'terser',
terserOptions: {
compress: {
drop_console: true, // 移除 console.log
drop_debugger: true,
},
},
rollupOptions: {
output: {
manualChunks: {
vendor: ['react', 'react-dom'], // 分離供應商套件
},
},
},
},
}

結果:

  • JavaScript 已壓縮(減少約 70%)
  • CSS 已壓縮(減少約 60%)
  • 影像已最佳化
  • 已套用搖樹優化

編譯器旗標:

Terminal window
-ldflags="-s -w"
  • -s:移除符號表(減少約 10%)
  • -w:移除 DWARF 除錯資訊(減少約 20%)

其他最佳化:

Terminal window
-ldflags="-s -w -X main.version=1.0.0"
  • -X:在建置時設定變數值
  • 適用於版本號、建置日期

UPX(選用):

Terminal window
# 建置後
upx --best build/bin/myapp.exe

結果:

  • 大小減少約 50%有關建置的問題? 請在 Discord 提問,或查看 建置範例