news 2026/1/29 15:23:36

electron通信方式有哪些?

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
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

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/1/24 10:50:55

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

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

作者头像 李华
网站建设 2026/1/28 16:22:05

无需PS!用Rembg大模型镜像一键生成透明背景图

无需PS!用Rembg大模型镜像一键生成透明背景图 你是否还在为商品图背景杂乱而烦恼?是否曾因无法快速抠出宠物或产品主体而不得不求助专业设计师?现在,无需Photoshop、无需手动描边、无需复杂操作——只需一个AI镜像,就能…

作者头像 李华
网站建设 2026/1/28 14:42:39

小白也能上手的深度估计方案|集成WebUI的MiDaS 3D感知镜像来了

小白也能上手的深度估计方案|集成WebUI的MiDaS 3D感知镜像来了 🌐 方案背景:从2D图像到3D空间感知 在计算机视觉领域,单目深度估计(Monocular Depth Estimation)是一项极具挑战性但又极具实用价值的技术。它…

作者头像 李华
网站建设 2026/1/23 21:24:55

从标签定义到智能打标:AI万能分类器全流程解析

从标签定义到智能打标:AI万能分类器全流程解析 在当今信息爆炸的时代,文本数据的自动化处理已成为企业提升效率、优化决策的核心能力。无论是客服工单的自动归类、用户反馈的情感分析,还是新闻内容的主题划分,智能文本分类都扮演着…

作者头像 李华
网站建设 2026/1/29 14:09:58

ResNet18多标签分类:预置镜像开箱即用,省去7天配环境时间

ResNet18多标签分类:预置镜像开箱即用,省去7天配环境时间 1. 为什么你需要这个预置镜像 想象一下,你刚接到一个紧急项目:客户要求用ResNet18的变体模型完成多标签分类任务。团队里没人熟悉PyTorch源码修改,自己配Doc…

作者头像 李华
网站建设 2026/1/25 22:41:15

CV教学新方案:ResNet18云端实验室,学生免配置

CV教学新方案:ResNet18云端实验室,学生免配置 1. 为什么需要云端实验室? 想象一下这样的场景:每次开课前,培训讲师需要帮50个学生安装Python环境、配置CUDA驱动、调试PyTorch版本。三分之一的学生电脑总会遇到各种奇…

作者头像 李华