electron-builder打包配置(应用名、安装包、图标、快捷方式、自定义文件关联启动等)

使用的是electron-vite + electron-builder

electron-builder.yml中配置,主要使用的是windows,其他配置请自行验证

yml 复制代码
appId: cn.kingray.www
# 只能string 不能用${productName}
productName: xx软件
copyright: Copyright © Powered by xx公司
directories:
  buildResources: build
  # output: release
files:
  - '!**/.vscode/*'
  - '!src/*'
  - '!electron.vite.config.{js,ts,mjs,cjs}'
  - '!{.eslintignore,.eslintrc.cjs,.prettierignore,.prettierrc.yaml,dev-app-update.yml,CHANGELOG.md,README.md}'
  - '!{.env,.env.*,.npmrc,pnpm-lock.yaml}'
  - '!{tsconfig.json,tsconfig.node.json,tsconfig.web.json}'
asarUnpack:
  - resources/**
  - out/main/chunks/*.node
asar:
  smartUnpack: true
# 设置自定义文件关联启动
fileAssociations:
  description: kingrayFile
  # 自定义文件后缀
  ext: krzj
  # 自定义文件图标
  icon: build/icons/win/icon.ico
win:
  # 只能string 不能用${productName}
  executableName: xx软件
  target: nsis
  # 必须为true 并且需要管理员运行
  signAndEditExecutable: true
  icon: build/icons/win/icon.ico
nsis:
  # 安装包名称
  artifactName: ${productName}-${version}-setup.${ext}
  # 快捷方式名称
  shortcutName: ${productName}
  # 卸载程序显示名称
  uninstallDisplayName: ${productName}
  # 是否创建桌面快捷方式
  createDesktopShortcut: always
  # 是否创建开始菜单快捷方式
  createStartMenuShortcut: true
  # 是否为单机版
  oneClick: false
  # 是否为机器级别安装
  perMachine: true
  # 是否允许更改安装目录
  allowToChangeInstallationDirectory: true
  # 是否在卸载时删除应用程序数据
  deleteAppDataOnUninstall: false
  # 安装程序图标
  installerIcon: build/icons/win/icon.ico
  # 卸载程序图标
  uninstallerIcon: build/icons/win/icon.ico
  # 安装程序头部图标
  installerHeaderIcon: build/icons/win/icon.ico
  # 安装程序侧边栏图标
  installerSidebar: build/icons/win/icon.ico
  # 许可证文件
  # license: build/license.txt
mac:
  entitlementsInherit: build/entitlements.mac.plist
  extendInfo:
    - NSCameraUsageDescription: Application requests access to the device's camera.
    - NSMicrophoneUsageDescription: Application requests access to the device's microphone.
    - NSDocumentsFolderUsageDescription: Application requests access to the user's Documents folder.
    - NSDownloadsFolderUsageDescription: Application requests access to the user's Downloads folder.
  notarize: false
dmg:
  artifactName: ${productName}-${version}.${ext}
linux:
  target:
    - AppImage
    - snap
    - deb
  maintainer: electronjs.org
  category: Utility
appImage:
  artifactName: ${productName}-${version}.${ext}
npmRebuild: false
publish:
  provider: generic
  url: http://192.168.2.32:8904/

其中${productName}、${version}对应的是package.json中的参数

json 复制代码
  "name": "app",
  "productName": "xx软件",
  "version": "2.0.2",

将png图标转化为ico

执行package.json中的脚本,使用electron-icon-maker,将resources/icon.png输出到build

json 复制代码
"build:icons": "electron-icon-maker --input=./resources/icon.png --output=./build",

目录

系统托盘图标

需要使用png,ico无法展示

ts 复制代码
    // ---- 窗口收纳于托盘 ---
    const trayIconPath = join(__dirname, '../../resources/icon.png')
    const trayIcon = nativeImage.createFromPath(trayIconPath)
    const tray = new Tray(trayIcon)

    // 设置托盘工具提示(鼠标悬停时的名称)
    tray.setToolTip('xx软件')

    // 创建上下文菜单
    const contextMenu = Menu.buildFromTemplate([
      { label: '显示应用', click: () => mainWindow?.show() },
      { label: '退出', click: () => app.quit() }
    ])
    tray.setContextMenu(contextMenu)

    // (可选)点击托盘图标显示/隐藏窗口
    tray.on('click', () => {
      if (mainWindow?.isVisible()) {
        mainWindow?.hide()
      } else {
        mainWindow?.show()
      }
    })
相关推荐
web打印社区2 天前
[特殊字符] 开源好物:web-print-pdf,让 Web 打印像调用接口一样简单!
前端·javascript·vue.js·electron
森总20203 天前
Electron 实战:utilityProcess 服务脚本热更新、用户目录优先启动与 asar 依赖解析
electron
政采云技术3 天前
从投标客户端看 Electron + React 工程化实践
electron
得想办法娶到那个女人3 天前
Vite + Vue 项目打包为 Electron 桌面应用 完整指南
前端·vue.js·electron
李李李勃谦3 天前
Vue3 + Electron + OpenHarmony 跨平台实战:从架构设计到 Markdown 编辑器完整实现
javascript·华为·electron·编辑器·harmonyos
森叶3 天前
Electron 实战:utilityProcess 服务脚本热更新、用户目录优先启动与 asar 依赖解析
前端·javascript·electron
森叶4 天前
Electron 实战:用 utilityProcess 开子进程,去端口化承载协议处理,并由主进程拦截渲染请求后统一中转
前端·javascript·electron
茅盾体4 天前
Electron图标相关
java·前端·electron
ejinxian4 天前
Rust GUI框架Azul与Electron、WebView2
前端·javascript·electron
孙凯亮6 天前
Electron 项目终极实战总结:从黑屏踩坑到自动更新全流程
前端·electron