electron通信方式有哪些?

一、Electron 进程模型先捋清(通信前提)

Electron 本质是多进程架构

  • 主进程(Main Process)

    • Node 环境

    • 负责窗口、系统能力、原生 API

  • 渲染进程(Renderer Process)

    • 浏览器环境(可选 Node)

    • 负责 UI(React / Vue)

👉进程隔离 → 必须通信


二、Electron 通信方式总览(面试必背)

通信方式适用场景是否推荐
ipcMain / ipcRenderer主进程 ↔ 渲染进程⭐⭐⭐⭐⭐
preload + contextBridge安全通信⭐⭐⭐⭐⭐
webContents.send主 → 指定渲染⭐⭐⭐⭐
BrowserWindow.webContents主控渲染⭐⭐⭐
MessageChannelMain多窗口/高并发⭐⭐⭐
remote(已废弃)早期同步调用
localStorage / IndexedDB同窗口共享⭐⭐
WebSocket / HTTP多实例/跨进程⭐⭐⭐

三、ipc 通信(你问的重点)

1️⃣ ipcRenderer → ipcMain(渲染 → 主)

🔹 ipcRenderer.send(异步,无返回)

// renderer ipcRenderer.send('open-file', { type: 'txt' }) // main ipcMain.on('open-file', (event, args) => { console.log(args) })

✅ 特点:

  • 单向

  • 不关心返回值

  • 常用于通知、触发动作


🔹 ipcRenderer.invoke(异步 + 有返回,⭐推荐)

// renderer const result = await ipcRenderer.invoke('get-version') // main ipcMain.handle('get-version', async () => { return app.getVersion() })

✅ 特点:

  • Promise 风格

  • 支持 async / await

  • 最推荐用法

📌 Electron 官方现在主推这个


2️⃣ ipcMain → ipcRenderer(主 → 渲染)

🔹 webContents.send

// main mainWindow.webContents.send('update-progress', 50) // renderer ipcRenderer.on('update-progress', (_, percent) => { console.log(percent) })

✅ 场景:

  • 主进程主动推送

  • 下载进度 / 系统事件


3️⃣ ipcRenderer.on(监听)

ipcRenderer.on('channel', (event, data) => {})

⚠️ 注意:

  • 页面销毁要removeListener

  • 否则内存泄漏


四、preload + contextBridge(安全通信,必会)

为什么要 preload?

  • 避免nodeIntegration: true

  • 防 XSS 直接拿 Node 权限

preload.js

const { contextBridge, ipcRenderer } = require('electron') contextBridge.exposeInMainWorld('electronAPI', { getVersion: () => ipcRenderer.invoke('get-version'), onUpdate: (cb) => ipcRenderer.on('update', cb) })

renderer

window.electronAPI.getVersion()

✅ 优点:

  • 安全

  • 可控

  • 官方推荐


五、ipc 的完整分类总结(你要的“ipc 都有哪些”)

📌 ipcRenderer 提供的方法

  • send(channel, ...args)

  • sendSync(channel, ...args)❌(不推荐)

  • invoke(channel, ...args)

  • on(channel, listener)

  • once(channel, listener)

  • removeListener

  • removeAllListeners


📌 ipcMain 提供的方法

  • on(channel, listener)

  • once(channel, listener)

  • handle(channel, handler)

  • removeHandler(channel)


六、其他 Electron 通信方式(扩展)

1️⃣ MessageChannelMain(多窗口通信)

const { port1, port2 } = new MessageChannelMain()

适合:

  • 多窗口

  • 大数据传输

  • 解耦 ipc channel


2️⃣ 渲染进程之间通信

不能直接通信

常见做法:

  • 渲染 A → 主 → 渲染 B

  • MessageChannelMain


3️⃣ Web 技术通信

  • WebSocket

  • HTTP

  • BroadcastChannel(同源)

适合:

  • 多实例

  • 多 Electron App


七、面试高频“加分点”

你可以这样说 👇:

“现在 Electron 官方推荐用ipcRenderer.invoke + ipcMain.handle
配合preload + contextBridge做安全通信,
避免开启 nodeIntegration 和 remote。”

面试官基本就点头了 👍


八、给你的实战建议(结合你前端经验)

  • 业务调用invoke / handle

  • 事件通知send / on

  • 统一封装:所有 ipc 放preload

  • 禁用 remote

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/1148532.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

AWAZLIKHAYAXORAX:一个神秘词汇的实际应用场景

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 设计一个应用,模拟AWAZLIKHAYAXORAX在密码学或品牌命名中的使用。用户可以输入该词汇,系统生成可能的加密代码或品牌标识建议。应用应包含可视化展示&#…

电商图片处理革命:Rembg自动化工作流

电商图片处理革命:Rembg自动化工作流 1. 引言:电商视觉升级的迫切需求 在当今竞争激烈的电商环境中,高质量的产品图是提升转化率的关键因素之一。传统的人工抠图耗时耗力,尤其面对海量商品上新时,效率瓶颈尤为突出。…

英伟达和MIT提出FoundationMotion:无需人工标注,轻量级模型运动理解媲美72B模型!

点击下方卡片,关注“CVer”公众号AI/CV重磅干货,第一时间送达点击进入—>【顶会/顶刊】投稿交流群添加微信号:CVer2233,小助手拉你进群!扫描下方二维码,加入CVer学术星球!可以获得最新顶会/顶…

5分钟快速验证:用Python3.10新特性开发小工具

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 开发一个命令行工具,利用Python3.10的结构模式匹配特性(match case)解析不同格式的日期字符串并统一输出。工具应支持多种日期格式(…

ResNet18模型转换指南:云端搞定ONNX/TensorRT导出

ResNet18模型转换指南:云端搞定ONNX/TensorRT导出 引言 作为一名嵌入式工程师,你是否遇到过这样的困扰:想把ResNet18模型部署到边缘设备上,但在本地转换时总是遇到各种报错?内存不足、CUDA版本冲突、依赖库缺失...这…

基于SpringBoot+Vue的购物推荐网站管理系统设计与实现【Java+MySQL+MyBatis完整源码】

摘要 随着电子商务的快速发展,个性化推荐系统在提升用户体验和促进消费方面发挥着重要作用。传统的购物网站往往缺乏精准的推荐机制,导致用户难以高效获取符合自身偏好的商品信息。基于此背景,设计并实现一个具备智能推荐功能的购物网站管理系…

无需Token!用MiDaS镜像实现高精度单目深度感知与可视化

无需Token!用MiDaS镜像实现高精度单目深度感知与可视化 🌐 技术背景:从2D图像中“看见”3D世界 在计算机视觉领域,单目深度估计(Monocular Depth Estimation) 是一项极具挑战性但又极具实用价值的技术。传…

零代码玩转单目深度估计|AI镜像集成WebUI,上传即出热力图

零代码玩转单目深度估计|AI镜像集成WebUI,上传即出热力图 “一张照片,还原三维世界。” 无需编程、无需GPU、无需Token验证——只需上传图片,即可秒级生成科技感十足的深度热力图。这不再是科幻场景,而是你触手可及的A…

5分钟快速验证:AI解决软件包依赖的原型

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 快速开发一个原型工具,验证AI解决Linux软件包依赖问题的可行性。工具应能够读取简单的软件包列表和依赖关系树,使用预训练的AI模型快速检测依赖冲突&#x…

AI如何简化YS9082HP主控开卡工具的开发流程

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 开发一个YS9082HP主控开卡工具,需要包含以下功能:1.自动检测连接的存储设备型号和固件版本 2.智能匹配最佳开卡参数配置 3.实时显示开卡进度和状态 4.错误自…

RYZEN SDT下载快速原型:5分钟验证你的想法

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 请生成一个快速验证RYZEN SDT下载功能的原型脚本,支持单文件下载和进度显示。脚本需简洁明了,无需额外依赖,能够在命令行中直接运行。使用Pytho…

Rembg模型应用:影视后期制作指南

Rembg模型应用:影视后期制作指南 1. 引言:智能万能抠图 - Rembg 在影视后期、广告设计与数字内容创作中,图像去背景是一项高频且关键的任务。传统手动抠图耗时费力,而基于AI的自动分割技术正逐步成为行业标配。其中,…

2026国内软文发布供应商综合实力排行榜发布 湖北敢当科技领跑行业

近日,第三方营销行业研究机构基于 2026 年近 3000 家企业服务实测数据,从媒体资源覆盖度、技术赋能能力、合规风控水平、客户口碑及效果转化效率五大核心维度,发布《2026 国内软文发布供应商综合实力评估报告》。榜单显示,湖北敢当…

Rembg性能瓶颈分析:识别与解决常见问题

Rembg性能瓶颈分析:识别与解决常见问题 1. 智能万能抠图 - Rembg 在图像处理与内容创作领域,自动去背景已成为一项高频刚需。无论是电商商品图精修、社交媒体素材制作,还是AI生成内容的后处理,精准高效的背景移除技术都扮演着关…

10分钟验证想法:系统分析师原型设计利器

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 创建一个极速系统原型设计工具,功能包括:1. 拖拽式界面创建业务流程;2. 实时生成架构示意图;3. 一键分享评审链接;4. 协…

ResNet18图像分类傻瓜教程:3步出结果,不用懂代码

ResNet18图像分类傻瓜教程:3步出结果,不用懂代码 引言:美术生的AI小助手 作为一名美术创作者,你是否遇到过这样的困扰:画作越来越多,整理分类却越来越费时间?给每幅作品手动添加标签就像在迷宫…

每日漫图 2.8.2 | 超多动漫高清头像和壁纸,二次元爱好者必备

每日漫图是一款专注于提供二次元高清头像和壁纸的应用程序。它为用户提供了各种精美的动漫头像和壁纸,涵盖不同风格和作品,都是超高清的4K壁纸图片。还能对动漫图片进行超分,拯救你的渣画质老婆图片😍。 直接安装使用即可。 大小…

5分钟验证你的选股想法:通达信指标快速原型开发

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 开发一个通达信指标快速原型工具。功能包括:1. 自然语言描述转指标代码;2. 即时回测反馈;3. 多版本快速迭代;4. 原型分享功能。要求…

Paper With Code:AI如何帮你自动实现论文算法

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 使用Kimi-K2模型,基于论文《Attention Is All You Need》中的Transformer架构,自动生成一个完整的PyTorch实现代码。要求包含多头注意力机制、位置编码和前…

Rembg抠图API调用教程:Python集成步骤详解

Rembg抠图API调用教程:Python集成步骤详解 1. 引言 1.1 智能万能抠图 - Rembg 在图像处理与内容创作领域,精准、高效的背景去除技术一直是核心需求。传统手动抠图耗时费力,而基于深度学习的自动抠图方案正逐步成为主流。其中,R…