【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('信道','参数') 发送消息

相关推荐
501mosthandsome36 分钟前
Electron+React框架搭建以及基础使用
前端·electron
页面仔Dony1 小时前
绝对路径与相对路径的区别及作用
前端·javascript
林太白1 小时前
Zustand状态库(简洁、强大、易用的React状态管理工具)
前端·javascript·react.js
YuJie1 小时前
vue3 无缝滚动
前端·javascript·vue.js
小野鲜1 小时前
前端打开新的独立标签页面,并且指定标签页的大小,管理新标签页面的打开和关闭(包含源码和使用文档)
前端·javascript
十五_在努力2 小时前
参透 JavaScript —— 解析浅拷贝、深拷贝及手写实现
前端·javascript
王六岁2 小时前
JavaScript值和引用详解:从栈堆内存到面试实战
javascript·面试
ikonan3 小时前
译:Chrome DevTools 实用技巧和窍门清单
前端·javascript
小高0073 小时前
⚡️ Vue 3.5 正式发布:10× 响应式性能、SSR 水合黑科技、告别 .value!
前端·javascript·vue.js
葡萄城技术团队3 小时前
【前沿解析】JavaScript 的未来,将迎来哪些新特性?
javascript