electron 设置开机自启动后 托盘图标无法显示

问题描述

electron 打包后的软件在设置开机自启动后,正常启动托盘图标可以显示,但开启自启动后,托盘图标却无法显示

问题解决

tray = new Tray(path.join(__dirname, './public/logo.png')); //必须是绝对路径和扩展名,像.png等

我的问题是图标之前设置为相对路径,而导致无法显示。将Tray的图标路径设定为绝对路径后,问题解决。

扩展

自启动的两种方式:

  1. 通过自带API
   app.setLoginItemSettings({
     openAtLogin: true,
     path: app.getPath('exe'),
   });
  1. 通过插件jsoncelectron-auto-launch
const AutoLaunch = require('electron-auto-launch');

let autoLaunch = new AutoLaunch({
  name: '可执行文件名称',
  path: app.getPath('exe'),
});

autoLaunch.isEnabled().then((isEnabled) => {
  if (!isEnabled) autoLaunch.enable();
});
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
要在 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
发出的红包

打赏作者

News777

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值