【Electron学习笔记(四)】进程通信(IPC)

进程通信(IPC)

进程通信(IPC)

前言

在Electron框架中,进程间通信(IPC)是构建功能丰富的桌面应用程序的关键。本文将深入探讨Electron中的IPC机制,主要包括三个方面:渲染进程到主进程的单向通信、渲染进程与主进程之间的双向通信,以及主进程到渲染进程的单向通信。通过ipcMain和ipcRenderer模块,Electron实现了不同进程间的消息传递,从而确保了应用程序的高效运行和功能的丰富性。

笔记源于:禹神:一小时快速上手Electron,前端Electron开发教程

正文

1、渲染进程→主进程(单向)

  • 概述 :在渲染器进程ipcRenderer.send 发送消息,在主进程 中使用 ipcMain.on 接收消息
  • 常用于在 Web 中调用主进程的 API ,例如下面这个需求:
    需求:点击按键后,在用户的 D 盘创建一个 hello.txt 的文件,文件内容来自于用户输入
  • 实现步骤
    1. index.html 页面中添加相关元素

    2. render.js 中添加对应脚本

    3. preload.js 中使用 ipcRenderer.send('信道','参数') 发送信息,与主进程通信

    4. main.js主进程中接收信息,并定义函数执行操作

2、渲染进程⇌主进程(双向)

  • 概述渲染进程 通过 ipcRenderer.invoke 发送消息 ,主进程使用 ipcMain.handle 接收并处理消息
    备注: ipcRenderer.invoke 的返回值是 Promise 实例
  • 常用于从渲染器进程调用主进程方法并等待结果 ,例如下面这个需求:
    需求:点击按键后,从 D 盘读取 hello.txt 的文件的内容,并将结果呈现在页面上
  • 实现步骤
    1. index.html 页面中添加相关元素

    2. render.js 中添加对应脚本

    3. preload.js 中使用 ipcRenderer.invoke('信道','参数') 发送信息,与主进程通信

    4. main.js 主进程中接收信息,并定义函数执行操作

    5. render.js 中接收从 main.js ->preload.js 得到的结果

3、主进程→渲染进程

  • 概述主进程 使用 win.webContents.send 发送消息,在渲染进程 中使用 ipcRenderer.on 接收消息
  • 常用于从主进程主动发送消息到渲染进程 ,例如下面这个需求:
    需求:应用加载6秒后,主动给渲染进程发送一个消息,内容是:hello
  • 实现步骤
    1. index.html 页面中添加相关元素, render.js 中添加对应脚本

    2. preload.js 中使用 ipcRenderer.send('信道','参数') 接收消息,并配置回调函数

    3. main.js 主进程中在合适的时候,使用 win.webContents.send('信道','参数') 发送消息

相关推荐
灵感__idea2 小时前
Hello 算法:贪心的世界
前端·javascript·算法
killerbasd5 小时前
牧苏苏传 我不装了 4/7
前端·javascript·vue.js
橘子编程6 小时前
JavaScript与TypeScript终极指南
javascript·ubuntu·typescript
叫我一声阿雷吧6 小时前
JS 入门通关手册(45):浏览器渲染原理与重绘重排(性能优化核心,面试必考
javascript·前端面试·前端性能优化·浏览器渲染·浏览器渲染原理,重排重绘·reflow·repaint
大家的林语冰7 小时前
《前端周刊》尤大开源 Vite+ 全家桶,前端工业革命启动;尤大爆料 Void 云服务新产品,Vite 进军全栈开发;ECMA 源码映射规范......
前端·javascript·vue.js
jiayong237 小时前
第 8 课:开始引入组合式函数
前端·javascript·学习
天若有情6738 小时前
【C++原创开源】formort.h:一行头文件,实现比JS模板字符串更爽的链式拼接+响应式变量
开发语言·javascript·c++·git·github·开源项目·模版字符串
yuki_uix8 小时前
重排、重绘与合成——浏览器渲染性能的底层逻辑
前端·javascript·面试
止观止9 小时前
拥抱 ESNext:从 TC39 提案到生产环境中的现代 JS
开发语言·javascript·ecmascript·esnext
时寒的笔记9 小时前
js逆向7_案例惠nong网
android·开发语言·javascript