पब्लिश करने की तारीख: 16 अगस्त, 2019
इमेज एलिमेंट की तरह, वीडियो को भी धीरे-धीरे लोड किया जा सकता है. आम तौर पर, वीडियो <video>
एलिमेंट के साथ लोड किए जाते हैं. हालांकि, YouTube जैसी अन्य सेवाओं पर होस्ट किए गए वीडियो के लिए, <iframe>
का इस्तेमाल किया जा सकता है. ऐसे में, लेज़ी-लोडिंग iframes लेख पढ़ें.
<video>
को लेज़ी-लोड करने का तरीका, इस्तेमाल के उदाहरण पर निर्भर करता है. ऐसा करने के लिए, कुछ अलग-अलग तरीके हैं.
ऐसे वीडियो के लिए जो अपने-आप नहीं चलते
आम तौर पर, वीडियो अपने-आप चलने की सुविधा बंद रखना सबसे सही होता है. इससे उपयोगकर्ता के पास वीडियो चलाने का कंट्रोल रहता है. इन मामलों में, पूरे वीडियो को लोड होने से रोकने का सबसे अच्छा तरीका यह है कि <video>
एलिमेंट पर preload
एट्रिब्यूट की वैल्यू सबमिट की जाए:
<video controls preload="none" poster="one-does-not-simply-placeholder.jpg">
<source src="one-does-not-simply.webm" type="video/webm">
<source src="one-does-not-simply.mp4" type="video/mp4">
</video>
पिछले उदाहरण में, preload
एट्रिब्यूट का इस्तेमाल किया गया है. इसकी वैल्यू none
है. इससे ब्राउज़र, किसी भी वीडियो डेटा को पहले से लोड नहीं कर पाते. poster
एट्रिब्यूट, <video>
एलिमेंट को एक प्लेसहोल्डर देता है. यह प्लेसहोल्डर, वीडियो लोड होने के दौरान उस जगह को भर देगा.
ज़्यादातर ब्राउज़र में preload
डिफ़ॉल्ट रूप से metadata
पर सेट होता है. साथ ही, Content-Range
हेडर का इस्तेमाल करके वीडियो का एक हिस्सा पहले से लोड हो जाता है. इस वजह से, ज़रूरत से ज़्यादा डेटा डाउनलोड हो सकता है. ऐसा खास तौर पर तब होता है, जब ब्राउज़र में Content-Range
हेडर काम न करता हो. इस सुविधा के काम करने के बावजूद, ब्राउज़र यह नहीं जान सकते कि मेटाडेटा किन बाइट में सेव किया गया है. ऐसा हो सकता है कि इसे फ़ाइल की शुरुआत में सेव न किया गया हो. इसलिए, वीडियो लोड होने से रोकने के लिए, none
की वैल्यू तय करें और preload="none"
का इस्तेमाल करें.
इस प्रोसेस को और बेहतर बनाया जा सकता है, ताकि जब उपयोगकर्ता onmouseenter
एट्रिब्यूट (या मिलते-जुलते mouseenter
इवेंट हैंडलर) वाले वीडियो पर कर्सर घुमाए, तो मेटाडेटा को पहले से लोड किया जा सके:
<video controls
preload="none"
poster="one-does-not-simply-placeholder.jpg"
onmouseenter="event.target.setAttribute('preload','metadata')">
<source src="one-does-not-simply.webm" type="video/webm">
<source src="one-does-not-simply.mp4" type="video/mp4">
</video>
इससे, वीडियो चलाने में लगने वाला समय कम हो जाता है. साथ ही, वीडियो चलाने पर उसे चलाने का कुल समय भी तुरंत दिखने लगता है.
वीडियो, एलसीपी उम्मीदवार के तौर पर स्वीकार किए जा सकते हैं. poster
इमेज, वीडियो के मुकाबले तेज़ी से लोड होगी. इसलिए, अगर यह एलसीपी एलिमेंट है, तो आपको पोस्टर इमेज का इस्तेमाल करना चाहिए. साथ ही, fetchpriority
एट्रिब्यूट की वैल्यू को "high"
पर सेट करके, इसे पहले से लोड करें:
<link rel="preload" href="one-does-not-simply-placeholder.jpg" as="image" fetchpriority="high">
<video controls preload="none"
poster="one-does-not-simply-placeholder.jpg"
onmouseenter="event.target.setAttribute('preload','metadata')">
<source src="one-does-not-simply.webm" type="video/webm">
<source src="one-does-not-simply.mp4" type="video/mp4">
</video>
ऐनिमेटेड GIF की जगह वीडियो का इस्तेमाल करने के लिए
अपने-आप चलने वाले वीडियो का इस्तेमाल, आम तौर पर GIF स्टाइल के क्विक ऐनिमेशन के लिए किया जाता है. एनिमेटेड GIF का इस्तेमाल काफ़ी किया जाता है. हालांकि, ये वीडियो के मुकाबले कई मामलों में कम बेहतर होते हैं. खास तौर पर, फ़ाइल साइज़ में. ऐनिमेशन वाले GIF फ़ाइलों का साइज़ कई मेगाबाइट तक हो सकता है. मिलती-जुलती विज़ुअल क्वालिटी वाले वीडियो का साइज़ काफ़ी छोटा होता है.
ऐनिमेशन वाले GIF की जगह <video>
एलिमेंट का इस्तेमाल करना, <img>
एलिमेंट के मुकाबले आसान नहीं है. ऐनिमेटेड GIF में ये तीन चीज़ें होती हैं:
- ये लोड होने पर अपने-आप चलने लगते हैं.
- वे लगातार लूप में चलते रहते हैं (हालांकि, ऐसा हमेशा नहीं होता).
- उनमें कोई ऑडियो ट्रैक न हो.
<video>
एलिमेंट की मदद से ऐसा करने पर, यह कुछ ऐसा दिखता है:
<video autoplay muted loop playsinline>
<source src="one-does-not-simply.webm" type="video/webm">
<source src="one-does-not-simply.mp4" type="video/mp4">
</video>
autoplay
, muted
, और loop
एट्रिब्यूट के बारे में अपने-आप जानकारी मिल जाती है. iOS पर वीडियो अपने-आप चलने के लिए, playsinline
की ज़रूरत होती है. अब आपके पास GIF के तौर पर वीडियो बदलने की सुविधा है, जो सभी प्लैटफ़ॉर्म पर काम करती है. लेकिन इसे लेज़ी लोड कैसे करें? शुरू करने के लिए, अपने <video>
मार्कअप में इन बदलावों को करें:
<video class="lazy" autoplay muted loop playsinline width="610" height="254" poster="one-does-not-simply.jpg">
<source data-src="one-does-not-simply.webm" type="video/webm">
<source data-src="one-does-not-simply.mp4" type="video/mp4">
</video>
आपको poster
एट्रिब्यूट दिखेगा. इसकी मदद से, वीडियो के लेज़ी-लोड होने तक <video>
एलिमेंट के स्पेस में प्लेसहोल्डर जोड़ा जा सकता है. <img>
लेज़ी-लोडिंग के उदाहरणों की तरह ही, हर <source>
एलिमेंट के data-src
एट्रिब्यूट में वीडियो का यूआरएल डालें. इसके बाद, इंटरसेक्शन ऑब्ज़र्वर पर आधारित इमेज को लेज़ी लोड करने के उदाहरणों की तरह ही JavaScript कोड का इस्तेमाल करें:
document.addEventListener("DOMContentLoaded", function() {
var lazyVideos = [].slice.call(document.querySelectorAll("video.lazy"));
if ("IntersectionObserver" in window) {
var lazyVideoObserver = new IntersectionObserver(function(entries, observer) {
entries.forEach(function(video) {
if (video.isIntersecting) {
for (var source in video.target.children) {
var videoSource = video.target.children[source];
if (typeof videoSource.tagName === "string" && videoSource.tagName === "SOURCE") {
videoSource.src = videoSource.dataset.src;
}
}
video.target.load();
video.target.classList.remove("lazy");
lazyVideoObserver.unobserve(video.target);
}
});
});
lazyVideos.forEach(function(lazyVideo) {
lazyVideoObserver.observe(lazyVideo);
});
}
});
किसी <video>
एलिमेंट को लेज़ी-लोड करने पर, आपको सभी चाइल्ड <source>
एलिमेंट को दोहराना होगा और उनके data-src
एट्रिब्यूट को src
एट्रिब्यूट में बदलना होगा. इसके बाद, आपको एलिमेंट के load
तरीके को कॉल करके, वीडियो लोड होने की प्रोसेस को ट्रिगर करना होगा. इसके बाद, मीडिया autoplay
एट्रिब्यूट के हिसाब से अपने-आप चलने लगेगा.
इस तरीके का इस्तेमाल करके, आपको एक ऐसा वीडियो विकल्प मिलता है जो ऐनिमेटेड GIF की तरह काम करता है. हालांकि, इसमें ऐनिमेटेड GIF की तरह ज़्यादा डेटा का इस्तेमाल नहीं होता. साथ ही, इस कॉन्टेंट को लेज़ी-लोड किया जा सकता है.
लेज़ी लोडिंग लाइब्रेरी
इन लाइब्रेरी की मदद से, वीडियो को धीरे-धीरे लोड किया जा सकता है:
- vanilla-lazyload और lozad.js, बहुत कम साइज़ वाले विकल्प हैं. ये सिर्फ़ इंटरसेक्शन ऑब्ज़र्वर का इस्तेमाल करते हैं. इसलिए, ये ऐप्लिकेशन बेहतर परफ़ॉर्म करते हैं. हालांकि, पुराने ब्राउज़र पर इनका इस्तेमाल करने से पहले, उन्हें पॉलीफ़िल करना होगा.
- yall.js एक लाइब्रेरी है, जो इंटरसेक्शन ऑब्ज़र्वर का इस्तेमाल करती है और इवेंट हैंडलर पर वापस आ जाती है. यह
data-poster
एट्रिब्यूट का इस्तेमाल करके, वीडियोposter
इमेज को भी धीरे-धीरे लोड कर सकता है. - अगर आपको React के लिए खास तौर पर बनी, धीरे-धीरे लोड होने वाली लाइब्रेरी की ज़रूरत है, तो react-lazyload का इस्तेमाल करें. हालांकि, इसमें इंटरसेक्शन ऑब्ज़र्वर का इस्तेमाल नहीं किया जाता, लेकिन React का इस्तेमाल करके ऐप्लिकेशन डेवलप करने वाले लोगों के लिए, यह इमेज को लेज़ी लोड करने का जाना-पहचाना तरीका देता है.
इनमें से हर एक लाइब्रेरी के बारे में अच्छी तरह से जानकारी दी गई है. साथ ही, इनमें लेज़ी लोडिंग के लिए कई मार्कअप पैटर्न मौजूद हैं.