electron基础

进程简介

electron有一个mian主进程和多个渲染进程(渲染进程至少有一个)
其中主进程与渲染进程需要preload进行通信。

preload是渲染进程与主进程进行通信的桥梁
主进程:控制应用生命周期,负责创建渲染进程,仅有一个。
渲染进程:每个窗口对应一个独立进程,支持Node.js和DOM API,数量可动态扩展。

ipc与webContents通信

renderer渲染进程通过ipc主动与主进程进行通信;

ipcRenderer.send(channel, ...args) 是异步的,用于从渲染进程向主进程发送消息。它发送消息后不会等待主进程的响应,而是立即返回,适合在不需要等待主进程响应的情况下发送消息。

ipcRenderer.invoke(channel, ...args) 是同步的,也是用于从渲染进程向主进程发送消息,但是它会等待主进程返回响应。它会阻塞当前进程,直到收到主进程的返回值或者超时。

ipcRenderer.sendSync(channel, ...args) 是用于从渲染进程向主进程发送消息,但是它是一个异步的方法,可以方便地在渲染进程中等待主进程返回 Promise 结果。相对于 send 和 sendSync,它更适合处理异步操作,例如主进程返回 Promise 的情况。

mian主进程通过webContents主动与renderer渲染进程进行通信

MessagePort可以实现渲染进程与渲染进程通信,不需要中间桥梁

preload:

  1. contextBridge - 安全桥接:

    contextBridge.exposeInMainWorld(),它把底层API包装成渲染进程可以直接调用的方法。

    安全性:只暴露我们需要的API,避免暴露整个Node.js环境

    可控性:我们可以对API进行包装和验证

    类型安全:可以为暴露的API提供TypeScript类型定义

  2. ipcRenderer - 进程间通信

    ipcRenderer是渲染进程用来与主进程通信的模块:

    ipcRenderer.invoke() - 发送请求并等待响应(异步)

    ipcRenderer.on() - 监听主进程发送的消息

    ipcRenderer.send() - 发送消息给主进程(不等待响应)

  3. 通信流程

    整个通信流程是这样的:

    渲染进程 → preload → ipcRenderer → 主进程 → ipcMain → 底层API

    底层API → ipcMain → 主进程 → ipcRenderer → preload → 渲染进程

mian主进程API

requestSingleInstanceLock() 单实例锁

单例锁(Singleton Lock)的实现主要用于确保应用程序在系统上只有一个实例运行。这对于桌面应用程序来说非常有用,尤其是在用户可能通过多种方式(如直接打开文件、从快捷方式等)启动应用程序时。

单实例锁的核心价值

在桌面应用开发中,多实例运行常常带来意想不到的问题:

配置文件冲突:多个进程同时读写设置导致数据损坏

文件锁定竞争:同一文件被多个窗口编辑造成内容覆盖

系统资源浪费:重复加载大型绘图组件导致内存占用激增

Mian主进程的index.ts根文件注册如下命令

html 复制代码
app.commandLine.appendSwitch('disable-site-isolation-trials')

作用:禁用 Chromium 的站点隔离功能

用途:提升性能,特别是在资源受限的环境中

html 复制代码
app.commandLine.appendSwitch('wm-window-animations-disabled')

作用:禁用窗口管理器的动画效果

用途:提升应用程序的响应速度,减少视觉延迟

html 复制代码
app.commandLine.appendSwitch('disable-web-security')

作用:关闭同源策略(Same-Origin Policy)

用途:允许跨域请求,便于开发和测试

html 复制代码
app.commandLine.appendSwitch('no-sandbox')

作用:关闭 Chromium 的沙盒安全机制

用途:解决在某些 Linux 环境或 Docker 容器中的兼容性问题

html 复制代码
app.commandLine.appendSwitch('high-dpi-support', 'true')

作用:优化高分辨率显示器的显示效果

用途:确保在高 DPI 屏幕上文字和界面元素清晰显示

相关推荐
苏宸啊5 小时前
Linux指令篇(一)
linux·运维·服务器
Nan_Shu_6146 小时前
学习: Threejs (1)
javascript·学习
我要升天!6 小时前
Linux中《网络基础》
linux·运维·网络
Van_Moonlight6 小时前
RN for OpenHarmony 实战 TodoList 项目:加载状态 Loading
javascript·开源·harmonyos
鸽芷咕7 小时前
【2025年度总结】时光知味,三载同行:落笔皆是沉淀,前行自有光芒
linux·c++·人工智能·2025年度总结
羑悻的小杀马特7 小时前
指尖敲代码,笔尖写成长:2025年度总结与那些没说出口的碎碎念
linux·c++·博客之星·2025年度总结
qq_406176148 小时前
关于JavaScript中的filter方法
开发语言·前端·javascript·ajax·原型模式
@@小旭8 小时前
实现头部Sticky 粘性布局,并且点击菜单滑动到相应位置
前端·javascript·css
晴天¥8 小时前
VMware+Oracle linux LVM/非LVM磁盘扩容
linux·运维·服务器
oMcLin8 小时前
如何在Oracle Linux 8.4上搭建并优化Kafka集群,确保高吞吐量的实时数据流处理与消息传递?
linux·oracle·kafka