इलेक्ट्रॉन - इंटर प्रोसेस कम्युनिकेशन
इलेक्ट्रॉन हमें 2 आईपीसी (इंटर प्रोसेस कम्युनिकेशन) मॉड्यूल प्रदान करता है जिसे कहा जाता है ipcMain तथा ipcRenderer।
ipcMainमॉड्यूल का उपयोग मुख्य प्रक्रिया से रेंडरर प्रक्रियाओं तक अतुल्यकालिक रूप से संचार करने के लिए किया जाता है। जब मुख्य प्रक्रिया में उपयोग किया जाता है, तो मॉड्यूल रेंडरर प्रक्रिया (वेब पेज) से भेजे गए अतुल्यकालिक और तुल्यकालिक संदेशों को संभालता है। एक रेंडरर से भेजे गए संदेश इस मॉड्यूल के लिए उत्सर्जित किए जाएंगे।
ipcRendererमॉड्यूल का उपयोग रेंडरर प्रक्रिया से मुख्य प्रक्रिया तक अतुल्यकालिक रूप से संचार करने के लिए किया जाता है। यह कुछ तरीके प्रदान करता है ताकि आप रेंडरर प्रक्रिया (वेब पेज) से मुख्य प्रक्रिया के लिए सिंक्रोनस और एसिंक्रोनस संदेश भेज सकें। आप मुख्य प्रक्रिया से उत्तर भी प्राप्त कर सकते हैं।
हम एक मुख्य प्रक्रिया और एक रेंडरर प्रक्रिया बनाएंगे जो उपरोक्त मॉड्यूल का उपयोग करके एक दूसरे को संदेश भेजेगा।
नामक एक नई फ़ाइल बनाएँ main_process.js निम्नलिखित सामग्री के साथ -
const {app, BrowserWindow} = require('electron')
const url = require('url')
const path = require('path')
const {ipcMain} = require('electron')
let win
function createWindow() {
win = new BrowserWindow({width: 800, height: 600})
win.loadURL(url.format ({
pathname: path.join(__dirname, 'index.html'),
protocol: 'file:',
slashes: true
}))
}
// Event handler for asynchronous incoming messages
ipcMain.on('asynchronous-message', (event, arg) => {
console.log(arg)
// Event emitter for sending asynchronous messages
event.sender.send('asynchronous-reply', 'async pong')
})
// Event handler for synchronous incoming messages
ipcMain.on('synchronous-message', (event, arg) => {
console.log(arg)
// Synchronous event emmision
event.returnValue = 'sync pong'
})
app.on('ready', createWindow)
अब एक नया बनाएँ index.html फ़ाइल और उसमें निम्न कोड जोड़ें।
<!DOCTYPE html>
<html>
<head>
<meta charset = "UTF-8">
<title>Hello World!</title>
</head>
<body>
<script>
const {ipcRenderer} = require('electron')
// Synchronous message emmiter and handler
console.log(ipcRenderer.sendSync('synchronous-message', 'sync ping'))
// Async message handler
ipcRenderer.on('asynchronous-reply', (event, arg) => {
console.log(arg)
})
// Async message sender
ipcRenderer.send('asynchronous-message', 'async ping')
</script>
</body>
</html>
निम्नलिखित कमांड का उपयोग करके एप्लिकेशन चलाएं -
$ electron ./main_process.js
उपरोक्त कमांड निम्नलिखित आउटपुट उत्पन्न करेगा -
// On your app console
Sync Pong
Async Pong
// On your terminal where you ran the app
Sync Ping
Async Ping
यह रेंडरर प्रक्रिया पर भारी / अवरुद्ध कार्यों की गणना नहीं करने की सिफारिश की जाती है। इन कार्यों को मुख्य प्रक्रिया में शामिल करने के लिए हमेशा IPC का उपयोग करें। यह आपके आवेदन की गति को बनाए रखने में मदद करता है।