تاریخ انتشار: 16 آگوست 2019
همانند عناصر تصویر ، ممکن است بخواهید ویدیو را با تنبلی بارگذاری کنید. ویدیوها معمولاً با عنصر <video>
بارگیری میشوند، اگرچه برای ویدیوهایی که در سرویسهای دیگر مانند YouTube میزبانی میشوند، ممکن است از <iframe>
استفاده کنند (در این صورت مقاله را در iframes با بارگذاری تنبل بررسی کنید).
نحوه بارگذاری تنبل <video>
بستگی به مورد استفاده دارد، زیرا چند راه حل مختلف وجود دارد.
برای ویدیویی که به صورت خودکار پخش نمی شود
اجتناب از پخش خودکار ویدیوها معمولاً بهترین روش است زیرا کنترل را به کاربر واگذار می کند. در این موارد، مشخص کردن ویژگی preload
در عنصر <video>
بهترین راه برای جلوگیری از بارگیری کل ویدیو است:
<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>
یک مکان نگهدار می دهد که در حین بارگذاری ویدیو فضا را اشغال می کند.
در اکثر مرورگرها، پیشفرضهای metadata
را preload
و بخشی از ویدیو با استفاده از سربرگ 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>
این نه تنها تاخیر زمانی که کاربر برای پخش ویدیو می رود را کاهش می دهد، بلکه مدت زمان ویدیو را به محض اینکه آنها را پخش می کند نشان می دهد.
ویدیوها می توانند به عنوان کاندیدای LCP واجد شرایط باشند. یک تصویر poster
سریعتر از ویدیو بارگیری می شود، بنابراین در جایی که این یک نامزد LCP است، باید از یک تصویر پوستر استفاده کنید، اما همچنین آن را با مقدار مشخصه 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 های متحرک می توانند تا محدوده چندین مگابایت داده گسترش یابند. ویدئوهایی با کیفیت بصری مشابه بسیار کوچکتر هستند.
استفاده از عنصر <video>
به عنوان جایگزینی برای GIF متحرک به اندازه عنصر <img>
ساده نیست. گیف های متحرک سه ویژگی دارند:
- آنها به طور خودکار در هنگام بارگذاری بازی می کنند.
- آنها به طور مداوم حلقه می زنند ( البته همیشه اینطور نیست ).
- تراک صوتی ندارند.
دستیابی به این مورد با عنصر <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
قابل توضیح هستند. playsinline
برای انجام پخش خودکار در iOS ضروری است . اکنون یک جایگزین قابل استفاده برای ویدیو به عنوان 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>
، URL ویدیو را در ویژگی data-src
روی هر عنصر <source>
ذخیره کنید. از آنجا، از کد جاوا اسکریپت مشابه نمونه های بارگذاری تنبل تصویر مبتنی بر Intersection Observer استفاده کنید:
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 گزینه های بسیار سبکی هستند که فقط از Intersection Observer استفاده می کنند. به این ترتیب، عملکرد بالایی دارند، اما قبل از استفاده از آنها در مرورگرهای قدیمی، باید چند پر شوند.
- yall.js کتابخانه ای است که از Intersection Observer استفاده می کند و به کنترل کننده رویداد باز می گردد. همچنین میتواند تصاویر
poster
ویدیویی را با استفاده از ویژگیdata-poster
بارگیری کند. - اگر به یک کتابخانه Lazy loading مخصوص React نیاز دارید، می توانید react-lazyload را در نظر بگیرید. در حالی که از Intersection Observer استفاده نمی کند، روشی آشنا برای بارگذاری تنبل تصاویر برای کسانی که به توسعه برنامه ها با React عادت دارند ارائه می دهد.
هر یک از این کتابخانههای بارگذاری تنبل به خوبی مستند شده است، با الگوهای نشانهگذاری فراوانی برای تلاشهای مختلف بارگیری تنبل شما.