Electron 后台常驻服务实现(托盘 + 开机自启)

基于 electron-vite-vue 项目结构

本篇将详细介绍如何为 Electron 应用实现后台常驻运行,包括:

  • ✅ 创建系统托盘图标(Tray)
  • ✅ 支持点击托盘菜单控制窗口显示/退出
  • ✅ 实现开机自启功能(Auto Launch)

📁 项目结构建议

electron-vite-vue/
├── electron/
│   ├── main/
│   │   ├── index.ts        # 主进程入口
│   │   ├── tray.ts         # 托盘功能实现
│   │   └── autostart.ts    # 开机启动功能
├── resources/
│   └── iconTemplate.png    # 托盘图标
├── src/
│   └── App.vue
└── package.json

🖼️ 1. 托盘功能实现(electron/main/tray.ts)

import { Tray, Menu, BrowserWindow, nativeImage, app } from 'electron'
import path from 'path'

let tray: Tray | null = null

export function createTray(win: BrowserWindow) {
  const icon = nativeImage.createFromPath(
    path.join(__dirname, '../../resources/iconTemplate.png')
  )
  icon.setTemplateImage(true) // macOS 支持暗黑模式适配

  tray = new Tray(icon)
  tray.setToolTip('我的 Electron 应用')

  const contextMenu = Menu.buildFromTemplate([
    { label: '显示窗口', click: () => win.show() },
    { label: '退出', click: () => { app.quit() } }
  ])
  tray.setContextMenu(contextMenu)

  tray.on('click', () => {
    win.isVisible() ? win.hide() : win.show()
  })

  tray.on('double-click', () => {
    win.show()
  })
}

🧩 2. 主窗口关闭时隐藏到托盘(electron/main/index.ts)

mainWindow.on('close', (e) => {
  if (!app.isQuiting) {
    e.preventDefault()
    mainWindow.hide()
  }
})

⚙️ 3. 开机启动功能(electron/main/autostart.ts)

import { app } from 'electron'

export function enableAutoLaunch() {
  app.setLoginItemSettings({
    openAtLogin: true,
    path: app.getPath('exe') // 自动获取应用路径
  })
}

Windows/macOS 默认支持。Linux 需要创建 .desktop 文件或使用 auto-launch 库。


🔗 4. 在主进程入口中调用(electron/main/index.ts)

import { enableAutoLaunch } from './autostart'
import { createTray } from './tray'

app.whenReady().then(() => {
  mainWindow = createWindow()
  enableAutoLaunch()
  createTray(mainWindow)
})

🧪 注意事项(平台兼容)

功能WindowsmacOSLinux
托盘✅ 完全支持✅ 支持(建议使用 Template 图标)⚠️ 依赖桌面环境
开机自启✅(需签名或添加权限)⚠️ 建议用 auto-launch

✅ 效果总结

功能项效果说明
托盘交互支持点击/双击托盘控制窗口
窗口关闭不退出程序,仅隐藏
托盘菜单显示主界面 / 退出程序
开机自启系统启动时自动运行 Electron 应用

📚 推荐阅读

要在 Windows 系统上实现 Electron 应用的开机动,可以通过以下步骤进行设置: 1. 在你的 Electron 应用项目中安装 "electron-squirrel-startup" 模块。该模块可以帮助你创建和删除开机动项。运行以下命令安装模块: ``` npm install --save-dev electron-squirrel-startup ``` 2. 在 Electron 主进程的入口文件中,添加以下代码来处理开机动: ```javascript const { app } = require('electron'); const { autoUpdater } = require('electron-updater'); const squirrelStartup = require('electron-squirrel-startup'); if (squirrelStartup) { // 如果是安装后第一次运行应用,则退出,让 Squirrel 处理自动逻辑 app.quit(); } // 其他主进程代码... ``` 3. 在 package.json 文件中,添加一个 "scripts" 配置项,用于设置应用安装和卸载时的自动逻辑。示例: ```json { "name": "your-electron-app", "version": "1.0.0", "scripts": { "start": "electron .", "postinstall": "electron-builder install-app-deps", "squirrel-startup": "squirrel --startup", "squirrel-uninstall": "squirrel --uninstall" }, "devDependencies": { "electron-squirrel-startup": "^1.0.0" } } ``` 4. 使用 electron-builder 构建你的应用。运行以下命令来生成安装程序: ``` npm run dist ``` 5. 在生成的安装程序所在目录中,找到应用的安装文件(例如:YourApp Setup x.x.x.exe)。运行以下命令来安装应用并设置开机动: ``` YourApp Setup x.x.x.exe --squirrel-install --createShortcut ``` 现在,通过以上步骤,你的 Electron 应用将会在 Windows 系统上实现开机动。 注意:以上步骤适用于 Windows 系统。对于其他操作系统如 macOS 或 Linux,你需要使用不同的方法来实现开机动功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值