इलेक्ट्रॉन - वेबव्यू

वेबव्यू टैग का उपयोग आपके इलेक्ट्रॉन ऐप में वेब पेजों की तरह 'अतिथि' सामग्री को एम्बेड करने के लिए किया जाता है। यह कंटेंट वेबव्यू कंटेनर के भीतर समाहित है। आपके ऐप के भीतर एक एम्बेडेड पृष्ठ नियंत्रित करता है कि यह सामग्री कैसे प्रदर्शित होगी।

वेबव्यू आपके ऐप से अलग प्रक्रिया में चलता है। दुर्भावनापूर्ण सामग्री से सुरक्षा सुनिश्चित करने के लिए, वेबव्यू में आपके वेब पेज के समान अनुमतियाँ नहीं हैं। यह आपके ऐप को एम्बेडेड कंटेंट से सुरक्षित रखता है। आपके एप्लिकेशन और एम्बेडेड पृष्ठ के बीच सभी इंटरैक्शन अतुल्यकालिक होंगे।

आइए हम अपने इलेक्ट्रॉन ऐप में एक बाहरी वेबपेज के एम्बेडिंग को समझने के लिए एक उदाहरण पर विचार करें। हम दायीं तरफ अपने ऐप में ट्यूटोरियलस्पॉट वेबसाइट को एम्बेड करेंगे। कोई नया बनाएंmain.js निम्नलिखित सामग्री के साथ फ़ाइल -

const {app, BrowserWindow} = require('electron')
const url = require('url')
const path = require('path')

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
   }))
}

app.on('ready', createWindow)

अब जब हमने अपनी मुख्य प्रक्रिया सेट कर ली है, तो आइए हम HTML फ़ाइल बनाते हैं जो ट्यूटोरियलस्पॉट वेबसाइट को एम्बेड करेगी। निम्न सामग्री के साथ index.html नामक एक फ़ाइल बनाएँ -

<!DOCTYPE html>
<html>
   <head>
      <meta charset = "UTF-8">
      <title>Menus</title>
   </head>
   
   <body>
      <div>
         <div>
            <h2>We have the website embedded below!</h2>
         </div>
         <webview id = "foo" src = "https://www.tutorialspoint.com/" style = 
            "width:400px; height:480px;">
            <div class = "indicator"></div>
         </webview>
      </div>
      
      <script type = "text/javascript">
         // Event handlers for loading events.
         // Use these to handle loading screens, transitions, etc
         onload = () => {
            const webview = document.getElementById('foo')
            const indicator = document.querySelector('.indicator')

            const loadstart = () => {
               indicator.innerText = 'loading...'
            }

            const loadstop = () => {
               indicator.innerText = ''
            }

            webview.addEventListener('did-start-loading', loadstart)
            webview.addEventListener('did-stop-loading', loadstop)
         }
      </script>
   </body>
</html>

निम्नलिखित कमांड का उपयोग करके एप्लिकेशन चलाएं -

$ electron ./main.js

उपरोक्त कमांड निम्नलिखित आउटपुट उत्पन्न करेगा -

वेबव्यू टैग का उपयोग अन्य संसाधनों के लिए भी किया जा सकता है। वेबव्यू तत्व में घटनाओं की एक सूची है जो इसे आधिकारिक डॉक्स पर सूचीबद्ध करती है। आप इन घटनाओं का उपयोग वेबव्यू में आने वाली चीजों के आधार पर कार्यक्षमता में सुधार के लिए कर सकते हैं।

जब भी आप इंटरनेट से स्क्रिप्ट या अन्य संसाधनों को एम्बेड कर रहे हैं, तो वेबव्यू का उपयोग करना उचित है। यह अनुशंसित है क्योंकि यह महान सुरक्षा लाभों के साथ आता है और सामान्य व्यवहार में बाधा नहीं डालता है।