在使用 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. 结论
很有效,大家复制代码测试一下。。。