Electron中Tray的setContextMenu导致窗口无法聚焦

在使用 Electron 开发应用时,经常会遇到使用 Tray(托盘)和设置上下文菜单(ContextMenu)导致窗口无法正常聚焦 的问题。这会导致用户无法在带有输入框的窗口中进行输入,影响应用的用户体验。

javascript 复制代码
tray.setContextMenu(menu)

其实这是由于带有输入框的窗口聚焦失败,无法输入导致,我们可以分两步进行处理。

解决方案

为了解决这个问题,我们可以采用以下步骤:

步骤 1:先对窗口进行聚焦

在设置 Tray 的 ContextMenu 之前,确保先对带有输入框的窗口进行聚焦。这可以通过 win.focus() 实现,其中 win 是窗口对象。

javascript 复制代码
// 先对窗口进行聚焦
win.focus();
步骤 2:设置 Tray 的 ContextMenu

在窗口聚焦后,再执行 tray.setContextMenu(menu) 操作,确保上下文菜单设置在正确的环境下。

javascript 复制代码
// 设置 Tray 的 ContextMenu
tray.setContextMenu(menu);

完整代码示例

javascript 复制代码
const { app, BrowserWindow, Tray, Menu } = require('electron');

let mainWindow;
let tray;

app.whenReady().then(() => {
  mainWindow = new BrowserWindow({
    width: 800,
    height: 600,
    webPreferences: {
      nodeIntegration: true,
    },
  });

  // 先对窗口进行聚焦
  mainWindow.focus();

  // 创建托盘菜单
  const trayMenu = Menu.buildFromTemplate([
    {
      label: 'Show Window',
      click: () => {
        if (mainWindow) {
          mainWindow.show();
          mainWindow.focus();
        }
      },
    },
    {
      label: 'Exit',
      click: () => {
        app.quit();
      },
    },
  ]);

  // 创建托盘
  tray = new Tray('path/to/tray/icon.png');
  tray.setToolTip('My Electron App');

  // 设置 Tray 的 ContextMenu
  tray.setContextMenu(trayMenu);

  // 监听窗口关闭事件
  mainWindow.on('closed', () => {
    mainWindow = null;
  });
});

// 在所有窗口关闭时退出应用
app.on('window-all-closed', () => {
  if (process.platform !== 'darwin') {
    app.quit();
  }
});

// 在 macOS 上点击 dock 图标时创建窗口
app.on('activate', () => {
  if (mainWindow === null) {
    createWindow();
  }
});

5. 结论

很有效,大家复制代码测试一下。。。

相关推荐
xxy-mm1 小时前
Javascript 中的继承
开发语言·javascript·ecmascript
锋行天下3 小时前
公司内网部署大模型的探索之路
前端·人工智能·后端
1024肥宅3 小时前
手写 EventEmitter:深入理解发布订阅模式
前端·javascript·eventbus
吃好喝好玩好睡好3 小时前
基于Flutter与OpenHarmony ArkUI组件互通的Electron桌面应用UI优化方案
flutter·ui·electron
海市公约5 小时前
HTML网页开发从入门到精通:从标签到表单的完整指南
前端·ide·vscode·程序人生·架构·前端框架·html
3秒一个大5 小时前
HTML5 与 JavaScript 中的二进制数据处理:ArrayBuffer 与 TextEncoder/Decoder 实践
javascript
purpleseashell_Lili5 小时前
如何学习 AG-UI 和 CopilotKit
javascript·typescript·react
行云流水6265 小时前
前端树形结构实现勾选,半勾选,取消勾选。
前端·算法
diudiu_335 小时前
web漏洞--认证缺陷
java·前端·网络
阿珊和她的猫6 小时前
<video>` 和 `<audio>` 标签的常用属性解析
前端