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

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

相关推荐
weixin199701080161 分钟前
《得物商品详情页前端性能优化实战》
前端·性能优化
帮我吧智能服务平台9 分钟前
装备制造企业售后服务数字化:从成本中心到利润中心背景
java·前端·制造
qq_3680196610 分钟前
用 react 的react-syntax-highlighter 实现语法高亮、行号与多行错误行高亮
前端·react.js·前端框架
lbh11 分钟前
从LLM到Agent的核心概念
前端·openai·ai编程
-Da-26 分钟前
【操作系统学习日记】并发编程中的竞态条件与同步机制:互斥锁与信号量
java·服务器·javascript·数据库·系统架构
Irene199128 分钟前
JavaScript脚本加载的两种方式:defer/async 的区别
前端·javascript·php
天若有情67333 分钟前
开篇必看:零基础吃透前端,别再盲目死记硬背了
前端
RulerMike38 分钟前
three 实现简单机械臂逆运动
前端·ai编程·three.js
darkb1rd40 分钟前
从“会聊天”到“会搭页面”:一次 TinyEngine + MCP 的前端智能化实战思路
前端
社恐的下水道蟑螂1 小时前
从奶茶店彻底搞懂 SSR!从零到拿捏服务端渲染,看完面试吹牛逼不卡壳
前端·react.js·性能优化