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

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

相关推荐
伊成4 分钟前
扫盲笔记之NPM
前端·笔记·npm
coding随想15 分钟前
JavaScript的三大核心组成:ECMAScript、DOM与BOM
开发语言·javascript·ecmascript
飞飞98727 分钟前
spring mvc
java·服务器·前端
sql1234567891131 分钟前
Vue-js
前端·javascript·vue.js
君的名字1 小时前
怎么判断一个Android APP使用了Electron 这个跨端框架
android·javascript·electron
哎哟喂_!1 小时前
深入解析Node.js文件系统(fs模块):从基础到进阶实践
javascript·chrome·node.js
何日成熟1 小时前
修改 vue-pdf 源码升级 pdfjs-dist 包, 以解决部分 pdf 文件显示花屏问题
前端·vue.js·pdf
橙子yq1 小时前
pdfjs-dist实现pdf预览偶现空白不报错问题解决
前端·javascript·pdf
itachi-uchiha1 小时前
Apache Apisix配置ip-restriction插件以限制IP地址访问
前端·firefox
每一天,每一步1 小时前
React+MapBox GL JS引入URL服务地址实现自定义图标标记地点、区域绘制功能
前端·javascript·react.js