- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在用 Electron js 编写一个桌面应用程序,我想将数据从我的主进程发送到我的渲染器进程,反之亦然。为此,我使用 ipcMain
和 ipcRenderer
,但很奇怪,同时能够通过我的渲染器发送数据 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
已经开除了。您应该提前设置它们,就像在创建窗口之前一样,或者只是删除 await
在 await createWin()
.
作为引用,Electron 抛出错误 here
关于javascript - Electron ipcMain 和 ipcRenderer 无法相互通信,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/67317027/
我的渲染过程中有以下内容: class Component { findClosestComponent(c) { /* Do stuff */ } } class Item extends
您好,我正在使用 Electron 和 React 开发一个项目, 我在 react 端有一个表单,在提交时调用 ipcRenderer.on 一个 ipcRenderer.send 方法。 我在为表
我正在尝试使用 IPC 在我的 react 组件和主 Electron 过程之间进行通信。 In component : export default class A extends React.Co
我可以看到“来自渲染器的你好”警报,但看不到“来自渲染器的再见”警报。 在 Windows 10 中运行。 而且我看不到“已收到!”警报,我应该看到 ipcRenderer.on(...) 起作用了。
我有一个带有构造函数和异步函数的类。 我已经完成了module.exports这样我就可以从我的 GUI.js 调用我的类(class)文件和我的GUI.js文件,我需要那个类,一切正常。 但是在我的
我正在做我的第一个 Electron 应用程序-使用Git中的 Electron 快速启动代码。 我无法将事件从preload.js发送到main.js 我成功地将邮件从main.js发送到prelo
所以显然使用 remote 是一种不好的做法。 Electron 中的模块,他们正计划杀死它。他们说ipcRenderer应该使用模块。 但是ipc的东西是一个事件系统。 如果在预加载脚本中我需要从主
我正在(第一次)使用 Electron 创建一个仅限 Mac 的小型应用程序。 我正在尝试使用 ipcRenderer 在我的应用程序菜单和主 BrowserWindow 中的内容之间进行通信。 我将
我有一个使用 Electron、React 和 React Router 的应用程序。我在组件构造函数中使用 ipcRenderer 将事件从组件发送到主 Electron 进程。将 React Ro
我正在使用 Electron + Vue 来构建我的应用程序。我向主进程发送一条消息以创建一个新窗口。在 main 的方法中,我试图将消息传递给新创建的窗口,但它不起作用。 我在主浏览器窗口中的 Ho
在我的主机应用程序中,我有一个按钮,单击该按钮后,会将数据连同数据一起发送到我的 Angular 应用程序。像这样: Send Some Data 组件: onClick() { ipcRender
我正在尝试做一个简单的 ipc.send 和 ipc.on 但由于某种原因我在这个 Electron 需求上变得不确定。 库/自定义菜单.js: 'use-strict'; const Browser
我想知道如何在 Electron 应用程序上通过 ipcRenderer 发送多个参数。我应该发送一个参数数组还是只发送用逗号分隔的所有参数? 谢谢, 最佳答案 我会推荐一个用于参数传输的对象。因此,
我正在尝试了解 Electron 主进程和渲染器进程之间的通信。文档 https://github.com/electron/electron/blob/master/docs/api/remote.
我正在使用 Electron 在我的 Ionic React 应用程序上制作桌面版本。我已经决定闪屏只会在 React 应用程序说它可以消失时才会消失。 在 index.ts (主要的 Electro
嗨,我是从ipcRenderer.send()文件中调用index.html的。 我想做的是将函数调用延迟5秒。但是,它似乎不起作用。 这实际上是我想要做的:setTimeout(ipcRendere
这是情况。 可通过main.js中的nodejs(node-adodb)直接访问该数据库。我的Angular应用发送请求并从db.service接收sql结果。这部分工作正常,但是如果我有一个类似ge
我正在尝试将消息从模式发送回浏览器窗口,以便使用从模式返回的数据更新它。 模态有一个表格,当您点击一行时,行 ID 通过 ipcRenderer 消息发送,但消息似乎没有到达那里,因为控制台中没有记录
我正在用 Electron js 编写一个桌面应用程序,我想将数据从我的主进程发送到我的渲染器进程,反之亦然。为此,我使用 ipcMain和 ipcRenderer ,但很奇怪,同时能够通过我的渲染器
使用 Electron、React (es6/jsx)、sass、pouchdb 和 webpack 2 设置。我无法导入或需要 ipcRenderer 来使主进程和渲染器进程之间的通信成为可能。我的
我是一名优秀的程序员,十分优秀!