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. 结论

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

相关推荐
前端老宋Running5 分钟前
一次从“卡顿地狱”到“丝般顺滑”的 React 搜索优化实战
前端·react.js·掘金日报
隔壁的大叔5 分钟前
如何自己构建一个Markdown增量渲染器
前端·javascript
用户4445543654267 分钟前
Android的自定义View
前端
WILLF8 分钟前
HTML iframe 标签
前端·javascript
枫,为落叶25 分钟前
Axios使用教程(一)
前端
小章鱼学前端30 分钟前
2025 年最新 Fabric.js 实战:一个完整可上线的图片选区标注组件(含全部源码).
前端·vue.js
ohyeah31 分钟前
JavaScript 词法作用域、作用域链与闭包:从代码看机制
前端·javascript
流星稍逝33 分钟前
手搓一个简简单单进度条
前端
uup37 分钟前
JavaScript 中 this 指向问题
javascript
倚栏听风雨1 小时前
详解 TypeScript 中,async 和 await
前端