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

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

tray.setContextMenu(menu)

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

解决方案

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

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

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

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

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

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

完整代码示例

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

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

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2023-12-19 03:52:02       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2023-12-19 03:52:02       106 阅读
  3. 在Django里面运行非项目文件

    2023-12-19 03:52:02       87 阅读
  4. Python语言-面向对象

    2023-12-19 03:52:02       96 阅读

热门阅读

  1. 【MySQL】(DDL)总结

    2023-12-19 03:52:02       63 阅读
  2. 常见SQL语句速通

    2023-12-19 03:52:02       54 阅读
  3. spring之基于注解管理Bean

    2023-12-19 03:52:02       48 阅读
  4. 【Unity】如何让Unity程序一打开就运行命令行命令

    2023-12-19 03:52:02       62 阅读
  5. 【redis】redis使用get及set功能,及发布订阅

    2023-12-19 03:52:02       59 阅读
  6. uniapp蓝牙

    2023-12-19 03:52:02       57 阅读
  7. log4j日志打印配置

    2023-12-19 03:52:02       69 阅读
  8. mysql 有哪些日志文件?都有哪些作用?

    2023-12-19 03:52:02       62 阅读
  9. 力扣LeetCode75题

    2023-12-19 03:52:02       83 阅读