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

相关推荐
漂流瓶jz13 小时前
Webpack中各种devtool配置的含义与SourceMap生成逻辑
前端·javascript·webpack
这是个栗子13 小时前
【问题解决】用pnpm创建的 Vue3项目找不到 .eslintrc.js文件 及 后续的eslint配置的解决办法
javascript·vue.js·pnpm·eslint
zy happy15 小时前
RuoyiApp 在vuex,state存储nickname vue2
前端·javascript·小程序·uni-app·vue·ruoyi
Nan_Shu_61415 小时前
学习:JavaScript(5)
开发语言·javascript·学习
533_15 小时前
[vue3] h函数,阻止事件冒泡
javascript·vue.js·elementui
通往曙光的路上15 小时前
day22_用户授权 头像上传
javascript·vue.js·ecmascript
meichaoWen15 小时前
【Vue】Vue框架的基础知识强化
前端·javascript·vue.js
西西学代码15 小时前
Flutter---DragTarget(颜色拖拽选择器)
前端·javascript·flutter
阿蓝灬16 小时前
React中的stopPropagation和preventDefault
前端·javascript·react.js
天天向上102416 小时前
vue3 抽取el-dialog子组件
前端·javascript·vue.js