gpt4 book ai didi

javascript - Electron ipcMain 和 ipcRenderer 无法相互通信

转载 作者:行者123 更新时间:2023-12-04 07:43:37 25 4
gpt4 key购买 nike

我正在用 Electron js 编写一个桌面应用程序,我想将数据从我的主进程发送到我的渲染器进程,反之亦然。为此,我使用 ipcMainipcRenderer ,但很奇怪,同时能够通过我的渲染器发送数据 ipcRenderer.send() ,我无法使用 ipcRenderer.on() 从我的主进程接收任何数据.它只是由于某种原因不起作用。
之后,我尝试按照 Electron 的文档编写测试来查找错误。然而,该测试根本不起作用,因为两个进程似乎都无法向另一个进程发送一些东西。这是我为测试编写的代码:
main.js :

const { app, ipcMain, BrowserWindow } = require('electron');

const createWin = async () => {
const win = new BrowserWindow({
webPreferences: {
nodeIntegration: true,
contextIsolation: false,
},
});
win.loadFile('./index.html');
return new Promise((resolve, reject) => {
win.once('ready-to-show', () => {
resolve();
});
});
};

app.whenReady().then(async () => {
const win = await createWin();
console.log('Ready to show');

ipcMain.on('asynchronous-message', (event, arg) => {
console.log(arg); // prints "ping"
event.reply('asynchronous-reply', 'pong');
});

ipcMain.on('synchronous-message', (event, arg) => {
console.log(arg); // prints "ping"
event.returnValue = 'pong';
});
});
index.html :
<!DOCTYPE html>
<html lang="en">
<head>
<title>Test, please work</title>
</head>
<body>
<script src="./app.js"></script>
</body>
</html>
app.js:
const { ipcRenderer } = require('electron');

console.log(ipcRenderer.sendSync('synchronous-message', 'ping')); // prints "pong"

ipcRenderer.on('asynchronous-reply', (event, arg) => {
console.log(arg); // prints "pong"
});
ipcRenderer.send('asynchronous-message', 'ping');
以下是渲染器记录的内容:
{ error: "reply was never sent" }
这是我从中获取代码的文档的链接: https://www.electronjs.org/docs/api/ipc-main#sending-messages

最佳答案

发生这种情况是因为您连接事件处理程序太晚了。
您只是添加 ipcMain.on页面加载后,ready-to-show已经开除了。您应该提前设置它们,就像在创建窗口之前一样,或者只是删除 awaitawait createWin() .
作为引用,Electron 抛出错误 here

关于javascript - Electron ipcMain 和 ipcRenderer 无法相互通信,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/67317027/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com