#reactjs #typescript #electron #electron-forge #tray
Вопрос:
Я создал проект с помощью electron forge (настройка с помощью webpack, react и typescript), и первое, что я сделал, это попытался добавить лоток в приложение. Но когда приложение инициализируется, примерно через 3 секунды лоток исчезает. Я прочитал несколько тем об этой ошибке, и все говорят, что поместить лоток в глобальную переменную-это решение, но со мной это не сработало, и лоток все еще исчезает
import { app, BrowserWindow, Menu, Tray } from 'electron';
declare const MAIN_WINDOW_WEBPACK_ENTRY: string;
let icon = null
if (require('electron-squirrel-startup')) { // eslint-disable-line global-require
app.quit();
}
const createWindow = (): void => {
// Create the browser window.
const mainWindow = new BrowserWindow({
height: 600,
width: 800,
});
mainWindow.loadURL(MAIN_WINDOW_WEBPACK_ENTRY);
mainWindow.webContents.openDevTools();
icon = new Tray('')
const contextMenu = Menu.buildFromTemplate([
{
label: 'teste', click: () => console.log('hello world')
}
])
icon.setContextMenu(contextMenu)
};
app.on('ready', createWindow);
app.on('window-all-closed', () => {
if (process.platform !== 'darwin') {
app.quit();
}
});
app.on('activate', () => {
// On OS X it's common to re-create a window in the app when the
// dock icon is clicked and there are no other windows open.
if (BrowserWindow.getAllWindows().length === 0) {
createWindow();
}
});
Ответ №1:
ошибка в строке
icon = new Tray('')
передача недопустимого URL-адреса не приводит к появлению пустого значка, как я думал, это приведет к сбою приложения, и лоток исчезнет, поэтому мне нужно указать действительный URL-адрес значка