2024-12-11【Electron】开发细节

1 主进程与渲染进程 预加载脚本

主进程

每个 Electron 应用都有一个单一的主进程,作为应用程序的入口点。 主进程在 Node.js 环境中运行,这意味着它具有 require 模块和使用所有 Node.js API 的能力

渲染器进程

每个 Electron 应用都会为每个打开的 BrowserWindow ( 与每个网页嵌入 ) 生成一个单独的渲染器进程。 洽如其名,渲染器负责 渲染 网页内容。 所以实际上,运行于渲染器进程中的代码是须遵照网页标准的 (至少就目前使用的 Chromium 而言是如此) 。

渲染进程本不参与node.js API使用,但有一些代码会由主进程暴露给渲染进程,用以在渲染进程环境中运行,优先于网页内容加载,即preload.js

开启渲染进程使用preload.js

方法1:关闭上下文隔离

function createMainWindow () {
    const mainWindow = new BrowserWindow({
        width: 800,
        height: 600,
        webPreferences: {
            nodeIntegration: true,
            contextIsolation: false,  // 关闭上下文隔离 渲染进程可访问node.js API
            preload: `${__dirname}/preload.js`  //${__dirname} 代表当前文件所在目录
        }
    });
    mainWindow.loadFile('src/index.html');
}

方法2:使用contexBridge模块 在preload.js文件中更改

const { contextBridge } = require('electron');

contextBridge.exposeInMainWorld("BASE_URL", "http://api.xxx.com");  //(名称,值)
contextBridge.exposeInMainWorld("HttpUtil", {
    get: (url, params) => {
        console.info("axios", url, params);
    },
    post: (url, data) => {
        console.info("axios-post", url, data);
    }
});

2 单向通信

2-1

实现功能:通过页面输入和点击,渲染进程向主进程发送请求,更改window属性,如应用标题名
总的步骤可区分为:
设计步骤:设计请求的触发——设计请求——设计响应
触发步骤:触发请求——发送请求——接受请求并响应


设计请求的触发

绘制输入框及发送按钮-index.html

<input type="text" id="title">
<button id="btn">修改标题</button>

绑定事件

<script>
        const title = document.getElementById('title');
        const btn = document.getElementById('btn');
        // 绑定事件
        btn.addEventListener('click', () => {
            const value = title.value;
            window.electronApi.setTitle(value);  // 向主进程发送消息
        });
</script>

设计请求

预加载:渲染进程只负责渲染画面,如要更改元素,需向其暴露操作接口
暴露接口通过预加载实现。

预加载需求分析-preload.js

  • 发送消息的模块ipcRenderer
  • 发送消息的实现
const { contextBridge, ipcRenderer } = require('electron');  //ipcRenderer 实现渲染进程与主进程之间的异步通信

contextBridge.exposeInMainWorld('electronApi', {  //暴露接口名与其实现 接口名就是对象名 实现就是对象的方法或子成员 
    setTitle: (title) => {
        ipcRenderer.send('set-title', title);  //通过ipcRenderer向主进程发送事件通知(事件/消息名称, 消息内容)
    },
});

设计监听与响应

主进程的请求处理-main.js
主进程监听渲染进程发送的消息,并做出响应

ipcMain.on('set-title', (event, title) => {
    BrowserWindow.getFocusedWindow().setTitle(title);  //获取当前焦点窗口并设置标题  event用以消息反馈
});

监听消息类型为“set-title”的消息,并做出响应


最终呈现


2-2

双向通信

2-1


3 DarkMode


4 应用菜单

5 托盘菜单

6 Notification 通知

主进程

渲染进程

7 快捷键

8 在线/离线检测

根据网络连接状态改变图标颜色

9 多窗口

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,142评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,298评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,068评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,081评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,099评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,071评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,990评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,832评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,274评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,488评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,649评论 1 347
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,378评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,979评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,625评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,796评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,643评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,545评论 2 352

推荐阅读更多精彩内容