在 electronJS 中,我创建了一个自定义应用程序菜单,我在其中将事件从主进程发送到渲染器进程,但现在发生的事情是我正在监听该事件多次运行的位置.因此,如果有人可以帮助我找到并解决错误.谢谢.这是我的代码:
In electronJS, I have created a custom application menu in which I'm sending the event from main process to renderer process, but now what happening is where I'm listening this event is running multiple times. So, if anyone could help me to find and resolve the error. Thanks. Here's my code:
label: test,
click: function (item, focusedWindow, event) {
mainWindow.webContents.send('test')
}
ipcRenderer.on('test', (event, action) => {
console.log('called')
})
现在这个console.log被打印了多次.
Now this console.log is printed multiple times.
原代码:
{
label: constants.APPLICATION_MENU.ARTICLE.MENU.KEYWORD.LABEL,
accelerator: constants.APPLICATION_MENU.ARTICLE.MENU.KEYWORD.ACCELERATOR,
click: function (item, focusedWindow, event) {
contents.send(constants.APPLICATION_MENU.ARTICLE.MENU.KEYWORD.EVENT)
}
}
created: function () {
ipcRenderer.on(constants.APPLICATION_MENU.ARTICLE.MENU.KEYWORD.EVENT, () => {
console.log('clicked')
})
},
尝试在你的关闭窗口函数中使用 ipc.removeAllListeners('your_name_channel'):
Try using ipc.removeAllListeners('your_name_channel') in your closed window function:
Your_Window.on('closed',()=>{
ipc.removeAllListeners('your_name_channel');
})
这篇关于Electron JS事件多次触发的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持html5模板网!
CSS 下拉导航CSS drop down navigation(CSS 下拉导航)
CSS动态水平导航菜单填充特定宽度(表格行为)CSS dynamic horizontal navigation menu to fill up specific width (table behavior)(CSS动态水平导航菜单填充特定宽度(表格行为))
如何在我的 CSS 下拉菜单中添加第三级?How to add a 3rd level to my CSS drop down menu?(如何在我的 CSS 下拉菜单中添加第三级?)
电子应用程序.多个html文件Electron app. Multiple html files(电子应用程序.多个html文件)
在 Electron 中使用 ipc 从渲染器设置全局变量Using ipc in Electron to set global variable from renderer(在 Electron 中使用 ipc 从渲染器设置全局变量)
在 Electron 中保存 JSONSaving JSON in Electron(在 Electron 中保存 JSON)