Electron主进程 管理 所有网页及其对应的渲染进程,而渲染进程只能管理相应的网页, 一个渲染进程的崩溃不会影响其他渲染进程;那么两个进程之间如何通讯呢?
Electron 有两种进程:主进程和渲染进程。
主进程
1. 主进程通过创建 BrowserWindow 实例来创建 网页。 每一个 BrowserWindow 实例在其渲染过程中运行网页, 当一个 BrowserWindow 实例被销毁时,对应的渲染过程也会被终止。
2.主进程 管理 所有网页及其对应的渲染进程。
渲染进程
1. 渲染进程只能管理相应的网页, 一个渲染进程的崩溃不会影响其他渲染进程。
2. 渲染进程通过 IPC 与主进程通信在网在页上执行 GUI 操作。 出于安全和可能的资源泄漏考虑,直接从渲染器进程中调用与本地 GUI 有关的 API 受到限制。
进程之间的通信可以通过 Inter-Process Communication(IPC) 模块进行:ipcMain 和 ipcRenderer
若要创建一个窗口,请调用 BrowserWindow 类,但只能在主进程中使用(main.js):
const { BrowserWindow } = require('electron') const win = new BrowserWindow()
若要从渲染进程调用主进程,请使用 IPC 模块: 例如净化窗口模式下自定义关闭窗口功能
1. 首先由主进程向渲染进程发送消息,告诉它窗口的id(开启了多个渲染进程);
win.once('ready-to-show', () => { win.webContents.send('init_win_id', win.id); win.show() });
2. 在渲染进程接收winid,并在关闭窗口时发送给主进程
//渲染进程监听init_win_id事件(自定义),将winid赋给全局变量winid let winid = ''; require('electron').ipcRenderer.on('init_win_id', (event, message) => { winid = message; }) // 关闭窗体 function closex(){ //渲染进程里把窗口id发给主进程 const { ipcRenderer } = require('electron') ipcRenderer.send('close_window', winid); }
3. 在主进程中接收需要关闭的渲染进程
// 主进程获取winid关闭窗体 ipcMain.on('close_window', (event, arg) => { //app.quit()单个窗口可以直接app.quit() //win.close(); // 1、接收渲染进程发来的窗口id let winid = arg; console.log(winid); // 2、通过id找到对应的BrowserWindow对象(win、win22),调用这个对象的close()关闭对应的窗口 BrowserWindow.fromId(winid).close(); })
以上就是electron制作QQ音乐客户端-主进程与渲染进程通讯的详细内容,更多请关注亿码酷站其它相关文章!
electron制作QQ音乐客户端-主进程与渲染进程通讯
—–文章转载自PHP中文网如有侵权请联系ymkuzhan@126.com删除
转载请注明来源:electron制作QQ音乐客户端-主进程与渲染进程通讯
本文永久链接地址:https://www.ymkuzhan.com/39454.html
本文永久链接地址:https://www.ymkuzhan.com/39454.html
下载声明:
本站资源如无特殊说明默认解压密码为www.ymkuzhan.com建议使用WinRAR解压; 本站资源来源于用户分享、互换、购买以及网络收集等渠道,本站不提供任何技术服务及有偿服务,资源仅提供给大家学习研究请勿作它用。 赞助本站仅为维持服务器日常运行并非购买程序及源码费用因此不提供任何技术支持,如果你喜欢该程序,请购买正版! 版权声明:
下载本站资源学习研究的默认同意本站【版权声明】若本站提供的资源侵犯到你的权益,请提交版权证明文件至邮箱ymkuzhan#126.com(将#替换为@)站长将会在三个工作日内为您删除。 免责声明:
您好,本站所有资源(包括但不限于:源码、素材、工具、字体、图像、模板等)均为用户分享、互换、购买以及网络收集而来,并未取得原始权利人授权,因此禁止一切商用行为,仅可用于个人研究学习使用。请务必于下载后24小时内彻底删除,一切因下载人使用所引起的法律相关责任,包括但不限于:侵权,索赔,法律责任,刑事责任等相关责任,全部由下载人/使用人,全部承担。以上说明,一经发布视为您已全部阅读,理解、同意以上内容,如对以上内容持有异议,请勿下载,谢谢配合!支持正版,人人有责,如不慎对您的合法权益构成侵犯,请联系我们对相应内容进行删除,谢谢!