Electron的原理是什么

2021/6/23 22:32:07
栏目: 其他类
开发者测试专用服务器限时活动,0元免费领,库存有限,领完即止! 点击查看>>

这篇文章将为大家详细讲解有关Electron的原理是什么,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

        在Electron应用中,GUI组件仅在主进程可用,在辅助进程中不可用。那如果想要在辅助进程中试用GUI组件,势必需要和主进程进行通信。ipc模块就是用来实现主进程和辅助进程之间的通信。在主进程中使用ipcMain模块进行对辅助进程的通信进行控制和处理。而在辅助进程中,则使用ipcRenderer模块,来向主进程发送消息或者接受主进程的回应。接下来我们来讲讲这两个模块是如何进行通信的。

        在主进程中使用ipcMain模块进行对辅助进程的通信进行控制和处理。ipcMain模块是EventEmitter的实例。ipcMain模块有四个监听方法:

ipcMain.on(channel, listener)

解析:监听事件channel,当新消息到达时,将执行监听方法listener(event, args)

ipcMain.once(channel, listener)

解析:为事件channel添加一个只执行一次的监听方法listener。在第一次消息到大时会调用listener,执行完毕马上删除listener.

ipcMain.removeListenner(channel, listener)

解析:从特定的channel的监听事件中删除特定的listener监听者。

ipcMain.removeAllListeners([channel])

解析:本方法可接受传参channel,若传参channel,则删除特定channel的所有监听者。若未进行传参,则删除所有监听者。

我们需要将event对象传递给callbackevent主要有两个方法:同步回复消息和异步回复消息

event.returnValue

解析:当主进程需要向辅助进程回复同步消息,则可以使用该方法。

event.sender.send('消息')

解析:当主进程需要向辅助进程回复异步消息,则可以使用本方法。

我们还是拿昨天的项目来继续用,我们来看看主进程和辅助进程之间如何进行通信的:

首先主进程我们说过了就是index.js文件,我们在里面使用ipcMain模块对消息进行处理:

const ipcMain = require('electron').ipcMain;
ipcMain.on('test-message', function (event, arg) {    event.sender.send('test-reply', '这是主进程');});
ipcMain.on('test-message', function (event, arg) {    event.returnValue = '这是主进程';});

辅助进程目前只有一个index.html页面,我们在里面使用ipcRenderer对消息进行处理

const ipcRenderer = require('electron').ipcRenderer;
console.log(ipcRenderer.sendSync('test-message', '这是辅助进程'));ipcRenderer.on('test-reply', function(event, arg) {  console.log(arg); });ipcRenderer.send('test-message''这是辅助进程');

我们使用electron .命令测试一下效果:

image.png

可以看到主进程成功进行通信了,那接下来我们来讲讲在辅助进程中ipcRenderer具体的使用方法吧。

辅助进程其实就相当于我们一个个的html文件,可以使用ipcRenderer来接受和发送消息以便与主进程进行交互。

ipcRenderer模块用来监听事件的有四个方法:

ipcRenderer.on(channel, listener)
ipcRenderer.once(channel, listener)
ipcRenderer.removeListenner(channel, listener)
ipcRenderer.removeAllListeners([channel])

这四个方法的含义和ipcMain一致,这里就不进行重复解释了。发送消息ipcRenderer一样有发送同步消息和发送异步消息两个方法:

ipcRenderer.send(channel, args)

解析:辅助进程使用该方法向主进程发送异步消息。主进程使用ipcMain模块对异步消息进行处理。

ipcRenderer.sendSync(channel, args)

解析:辅助进程使用该方法向主进程发送同步消息。主进程使用ipcMain模块对同步消息进行处理然后通过event.returnValue进行相应消息给辅助进程。在这里我的建议是尽量少用同步消息,因为发送同步消息会阻塞整个页面渲染进程,对于用户体验来说是非常糟糕的一件事情。

ipcRenderer其实还有一个方法用来发送消息:

ipcRenderer.sendToHost(channel, args)

关于Electron的原理是什么就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。


辰迅云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>

推荐阅读: Hive实现列转行的方法是什么