Electron 主进程与渲染进程之间的通 信(同步通信、异步通信)
有时候我们想在渲染进程中通过一个事件去执行主进程里面的方法。或者在渲染进程中通知
主进程处理事件,主进程处理完成后广播一个事件让渲染进程去处理一些事情。这个时候就
用到了主进程和渲染进程之间的相互通信。
Electron 主进程,和渲染进程的通信主要用到两个模块:ipcMain 和 ipcRenderer
ipcMain:当在主进程中使用时,它处理从渲染器进程(网页)发送出来的异步和同步信息,
当然也有可能从主进程向渲染进程发送消息。
ipcRenderer: 使用它提供的一些方法从渲染进程 (web 页面) 发送同步或异步的消息到主
进程。 也可以接收主进程回复的消息。
场景 1:渲染进程给主进程发送异步消息:
//渲染进程 const { ipcRenderer } = require('electron') i pcRenderer.send('msg',{name:'张三'}); //异步
主进程:
//主进程 const { ipcMain } = require('electron'); ipcMain.on(''msg'',(event,arg) => { })
场景 2:渲染进程给主进程发送异步消息,主进程接收到异步消息以后通知渲染进程
//渲染进程 const { ipcRenderer } = require('electron') ipcRenderer.send('msg',{name:'张三'}); //异步
//主进程 const { ipcMain } = require('electron'); ipcMain.on(''msg'',(event,arg) => { event.sender.send('reply', 'pong'); })
//渲染进程 const { ipcRenderer } = require('electron') ipcRenderer.on('reply', function(event, arg) { console.log(arg); // prints "pong" } );
场景 3:渲染进程给主进程发送同步消息:
//渲染进程 const { ipcRenderer } = require('electron') const msg = ipcRenderer.sendSync('msg-a'); console.log(msg)
//主进程 ipcMain.on('msg-a',(event)=> { event.returnValue = 'hello'; })
最后,关注【码上加油站】微信公众号后,有疑惑有问题想加油的小伙伴可以码上加入社群,让我们一起码上加油吧!!!
posted on 2020-12-08 20:59 LoaderMan 阅读(1316) 评论(0) 编辑 收藏 举报