इलेक्ट्रॉन - इंटर प्रोसेस कम्युनिकेशन

इलेक्ट्रॉन हमें 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 का उपयोग करें। यह आपके आवेदन की गति को बनाए रखने में मदद करता है।