⊗jsSpAsnIL 153 of 294 menu

जावास्क्रिप्ट में छवियों की अतुल्यकालिक लोडिंग

जावास्क्रिप्ट के माध्यम से गतिशील रूप से बनाई गई छवियाँ भी अतुल्यकालिक रूप से लोड होती हैं। उदाहरण के लिए निम्नलिखित कोड पर विचार करें:

let image = document.createElement('img'); image.src = 'img.png'; document.body.appendChild(image);

जैसा कि आप देख रहे हैं, यहाँ हम img टैग बना रहे हैं, इसके src में छवि का पथ लिख रहे हैं और इस छवि को body में रख रहे हैं। हालाँकि, छवि पृष्ठ पर तुरंत दिखाई नहीं देगी। बात यह है कि जब हमने src में छवि का पथ लिखा - ब्राउज़र वेबसाइट से इस छवि को डाउनलोड करना शुरू कर देता है। जैसे ही छवि डाउनलोड हो जाएगी, तभी ब्राउज़र इसे दिखा पाएगा।

यदि छवि काफी बड़ी है, और इंटरनेट की गति काफी कम है, तो साइट का उपयोगकर्ता कुछ समय के लिए खाली छवि को "निहार" सकेगा - जब तक कि वह लोड नहीं हो जाती।

असल में img टैग का एक इवेंट load होता है, जो छवि के लोडिंग समाप्त होने पर ट्रिगर होता है:

let image = document.createElement('img'); image.src = 'img.png'; image.addEventListener('load', function() { // छवि के लोड होने पर ट्रिगर होगा });

हम इसका उपयोग यह सुनिश्चित करने के लिए कर सकते हैं कि छवि को पृष्ठ पर तभी रखा जाए जब वह छवि लोड हो जाए:

let image = document.createElement('img'); image.src = 'img.png'; image.addEventListener('load', function() { document.body.appendChild(image); // लोड होने पर रखते हैं });

छवि का लोड होना जरूरी नहीं है: ऐसा हो सकता है कि छवि का पथ गलत हो, या इंटरनेट कनेक्शन टूट जाए, साइट का सर्वर खराब हो जाए या कुछ ऐसा ही हो। दूसरे शब्दों में कहें तो - अपवाद स्थिति। इस मामले में, load इवेंट नहीं, बल्कि error इवेंट ट्रिगर होगा:

let image = document.createElement('img'); image.src = 'img.png'; image.addEventListener('load', function() { document.body.appendChild(image); }); image.addEventListener('error', function() { // छवि लोडिंग में त्रुटि });

एक बटन बनाएं, जिसे दबाने पर एक छवि लोड होगी। छवि को तब दिखाएं जब वह लोड हो जाए। छवि लोड होने में समस्या होने पर एक संदेश प्रदर्शित करें।

kaswrobyhu