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

使用 electron-builder 打包与发布 Electron 应用

基于 electron-vite-vue 项目结构

本文将基于 electron-vite-vue 脚手架,详细介绍如何使用 electron-builder 实现:

  • ✅ 多平台打包(Windows / macOS / Linux)
  • ✅ 自动更新发布配置
  • ✅ 常用构建脚本与输出结构

📁 项目结构

electron-vite-vue/
├── electron/                 # 主进程代码
├── src/                      # 渲染进程代码(Vue)
├── dist/                     # 渲染构建输出(vite 自动生成)
├── dist-electron/           # 主进程和安装包构建输出
├── package.json              # 配置文件(包含 build 字段)

🚀 安装依赖

npm install -D electron-builder

electron-vite-vue 中已集成打包脚本(通常在 package.jsonscripts 字段):

"scripts": {"dev": "electron-vite dev","build": "electron-vite build","build:dir": "electron-builder build","build:win": "electron-builder --win","build:mac": "electron-builder --mac"
}

⚙️ 基本构建配置(package.json 中的 build 字段)

"build": {"appId": "com.example.app","productName": "MyApp","directories": {"output": "dist-electron"},"files": ["dist","electron","node_modules"],"win": {"target": "nsis"},"mac": {"target": "dmg"},"publish": {"provider": "github","owner": "yourname","repo": "your-repo"}
}

📦 打包命令说明

命令功能
npm run build构建渲染进程 (Vite)
npm run build:dir打包主进程和产物
electron-builder --win构建 Windows 安装包
electron-builder --mac构建 macOS DMG
electron-builder -p never仅打包不发布
electron-builder -p always打包并自动发布

📁 打包输出结构

输出目录通常为 dist-electron/,包含:

  • Windows:
    • MyApp Setup 1.0.0.exe
    • latest.yml
    • blockmap(如启用增量更新)
  • macOS:
    • MyApp-1.0.0.dmg
    • latest-mac.yml

🔧 自动更新配置(publish)

GitHub 发布

"publish": {"provider": "github","owner": "yourname","repo": "your-repo"
}
  • 使用 GH_TOKEN 环境变量授权发布
  • 发布内容包括 .exe/.dmg + .yml 文件

Generic 发布(静态服务器)

"publish": {"provider": "generic","url": "https://your-domain.com/updates/"
}

⚠️ 需手动上传构建产物


🔐 macOS 注意事项

  • 签名/公证对于自动更新是必须的
  • 推荐使用 Apple Developer ID + notarize 配合发布

🧪 调试建议

  • 添加日志模块 electron-log
  • 设置日志等级 autoUpdater.logger = log
  • 可通过 --config 传入额外构建配置

✅ 推荐实践流程

  1. 设置 build 字段(含 publish)
  2. 执行渲染构建:npm run build
  3. 执行打包构建:npm run build:dir 或指定平台构建
  4. 上传产物到 GitHub Release 或服务器
  5. 应用中启用 electron-updater 自动更新逻辑

📚 延伸阅读

  • electron-builder 官方文档
  • electron-updater 文档
  • electron-vite-vue 模板仓库
http://www.lryc.cn/news/2383990.html

相关文章:

  • 微信小程序中,解决lottie动画在真机不显示的问题
  • Wireshark 抓包工具使用
  • 大语言模型(LLM)本身是无状态的,怎么固化记忆
  • JUC入门(六)
  • std::chrono类的简单使用实例及分析
  • Git命令汇总(自用,持续更新update 5/23)
  • window xampp apache使用腾讯云ssl证书配置https
  • MATLAB求解二元一次方程组基础教程
  • Android13 wifi设置国家码详解
  • 逆向音乐APP:Python爬虫获取音乐榜单 (1)
  • JVM 垃圾回收器
  • Java合并两个列表到目标列表,并且进行排序
  • Spring AI Alibaba集成阿里云百炼大模型应用
  • 22. 用例依赖装饰器的实现思路和方法
  • 支持向量存储:PostgresSQL及pgvector扩展详细安装步骤!老工程接入RAG功能必备!
  • 【部署】如何离线环境创建docker容器执行python命令行程序
  • idea常用配置 properties中文输出乱码
  • 【Bluedroid】蓝牙 HID Host connect全流程源码解析
  • day1 大模型学习 Qwen系列学习
  • Unity3D仿星露谷物语开发47之砍树时落叶特效
  • 第十节第六部分:常见API:DateTimeFormatter、Period、Duration
  • 如何在VSCode中更换默认浏览器:完整指南
  • B2160 病人排队
  • 【机器人】复现 3D-Mem 具身探索和推理 | 3D场景记忆 CVPR 2025
  • 鸿蒙进阶——CMakelist、GN语法简介及三方库通用移植指南
  • CSS-5.1 Transition 过渡
  • TTS:VITS-fast-fine-tuning 快速微调 VITS
  • 从虚拟仿真到行业实训再到具身智能--华清远见嵌入式物联网人工智能全链路教学方案
  • 告别手动绘图!2分钟用 AI 生成波士顿矩阵
  • GraphPad Prism工作表的管理