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

相关推荐
玫城2 小时前
[ VUE ] 封装通用数组校验组件,el-input内使用
前端·javascript·vue.js
弓.长.6 小时前
React Native 鸿蒙跨平台开发:实现一个多功能单位转换器
javascript·react native·react.js
摘星编程6 小时前
React Native for OpenHarmony 实战:ToggleSwitch 切换开关详解
javascript·react native·react.js
满栀5857 小时前
分页插件制作
开发语言·前端·javascript·jquery
qq_406176147 小时前
深入剖析JavaScript原型与原型链:从底层机制到实战应用
开发语言·前端·javascript·原型模式
弓.长.7 小时前
React Native 鸿蒙跨平台开发:BottomSheet 底部面板详解
javascript·react native·react.js
摘星编程8 小时前
React Native for OpenHarmony 实战:Permissions 权限管理详解
javascript·react native·react.js
闲蛋小超人笑嘻嘻8 小时前
Vue 插槽:从基础到进阶
前端·javascript·vue.js
摘星编程8 小时前
React Native for OpenHarmony 实战:SearchBar 搜索栏详解
javascript·react native·react.js
梦65010 小时前
Vue 单页面应用 (SPA) 与 多页面应用 (MPA) 对比
前端·javascript·vue.js