آموزش رفع خطای Defer offscreen images

آموزش رفع خطای Defer offscreen images

تعویق بارگذاری تصاویر خارج از دید یک تکنیک مهم بهینه‌سازی است که هدف آن بهبود سرعت بارگذاری صفحات وب و عملکرد کلی آن است. این روش شامل تأخیر در بارگذاری تصاویری است که در لحظه اولیه قابل مشاهده نیستند تا زمانی که کاربر به بخش مربوطه صفحه اسکرول کند. این رویکرد زمان بارگذاری اولیه صفحه را کاهش داده، مصرف پهنای باند را بهینه کرده و تجربه کاربری را بهبود می‌بخشد. از این رو، این روش یکی از عوامل حیاتی در ارزیابی و بهینه‌سازی سایت به شمار می‌رود.

چرا تعویق بارگذاری تصاویر خارج از دید اهمیت دارد؟

  1. بهبود زمان بارگذاری: با بارگذاری تنها محتوای قابل مشاهده در ابتدا، زمان لازم برای آماده‌سازی صفحه به‌طور قابل توجهی کاهش می‌یابد.
  2. بهینه‌سازی مصرف پهنای باند: کاربران تنها تصاویر مرتبط را بارگذاری می‌کنند که برای کاربران موبایل یا کسانی که از طرح‌های محدود اینترنتی استفاده می‌کنند بسیار مفید است.
  3. ارتقای تجربه کاربری: یک وب‌سایت سریع‌تر، رضایت کاربران را افزایش داده، نرخ پرش را کاهش داده و تعامل بیشتری را ایجاد می‌کند.
  4. مزایای سئو: الگوریتم‌های گوگل به وب‌سایت‌های سریع‌تر اولویت می‌دهند و اجرای این بهینه‌سازی می‌تواند متریک‌های حیاتی وب مانند اولین نقاشی محتوایی (FCP) و بزرگ‌ترین نقاشی محتوایی (LCP) را بهبود بخشد.

چگونه بارگذاری تصاویر خارج از دید را به تعویق بیندازیم؟

  1. پیاده‌سازی Lazy Loading: از ویژگی loading="lazy" در تگ‌های تصویر استفاده کنید. این ویژگی HTML بومی که توسط اکثر مرورگرهای مدرن پشتیبانی می‌شود، بارگذاری تصاویر را تا زمان نیاز به تعویق می‌اندازد.
  2. استفاده از کتابخانه‌های جاوااسکریپت: کتابخانه‌هایی مانند Lazysizes یا Lozad.js قابلیت‌های پیشرفته‌ای برای بارگذاری تنبل ارائه می‌دهند، از جمله تصاویر جایگزین و انتقال‌های نرم.
  3. شبکه‌های تحویل محتوا (CDNs): بسیاری از شبکه‌های تحویل محتوا قابلیت‌های بارگذاری تنبل را به‌صورت داخلی ارائه می‌دهند و اجرای آن را ساده‌تر می‌کنند.
  4. بهینه‌سازی اولویت‌های نمایشی: اطمینان حاصل کنید که تصاویر حیاتی، مانند محتوای بالای صفحه، از تعویق بارگذاری مستثنی باشند تا ثبات بصری و تعامل کاربر حفظ شود.

بهترین روش‌ها برای تعویق بارگذاری تصاویر

  • Lazy loading را با استفاده از فرمت‌های مدرن مانند WebP یا AVIF برای رندر سریع‌تر و کاهش حجم فایل ترکیب کنید.
  • برای مرورگرهایی که از ویژگی loading="lazy" پشتیبانی نمی‌کنند، از راه‌حل‌های جایگزین مانند پلی‌فیل‌ها یا اسکریپت‌های جاوااسکریپت استفاده کنید.
  • از ابزارهایی مانند Lighthouse یا PageSpeed Insights برای شناسایی تصاویر خارج از دید و تأیید پیاده‌سازی Lazy Loading استفاده کنید.

مزایای Lazy Loading

  1. کاهش زمان بارگذاری اولیه (First Load Time): با بارگذاری محتوای ضروری، صفحه سریع‌تر در دسترس کاربر قرار می‌گیرد.
  2. صرفه‌جویی در پهنای باند: منابع فقط زمانی دانلود می‌شوند که کاربر به آنها نیاز داشته باشد.
  3. بهبود تجربه کاربری: سایت سریع‌تر واکنش نشان می‌دهد و کاربران رضایت بیشتری خواهند داشت.
  4. بهبود رتبه‌بندی SEO: زمان بارگذاری سریع‌تر می‌تواند بر رتبه‌بندی گوگل تأثیر مثبت بگذارد.
 

چگونه Lazy Loading را پیاده‌سازی کنیم؟

  1. استفاده از ویژگی Native Lazy Loading
  • مرورگرهای مدرن مانند کروم و فایرفاکس از ویژگی loading="lazy" پشتیبانی می‌کنند.
  • نحوه استفاده:
html Copy code <img src="example.jpg" alt="Example" loading="lazy">
  • مزایا:
    • پیاده‌سازی آسان.
    • عدم نیاز به کتابخانه یا کدهای اضافی.
  1. استفاده از کتابخانه‌های JavaScript
برای مرورگرهای قدیمی یا عملکرد پیشرفته‌تر، می‌توانید از کتابخانه‌های Lazy Loading استفاده کنید:
  • LazyLoad.js:
    • ویژگی‌ها: سبک و سریع.
    • نحوه استفاده:
html Copy code <img class="lazy" data-src="example.jpg" alt="Example"> <script src="lazyload.min.js"></script> <script> document.addEventListener("DOMContentLoaded", function () { var lazyLoadInstance = new LazyLoad({ elements_selector: ".lazy" }); }); </script>
  • Lozad.js:
    • ویژگی‌ها: پشتیبانی از Intersection Observer API.
    • نحوه استفاده:
html Copy code <img class="lozad" data-src="example.jpg" alt="Example"> <script src="lozad.min.js"></script> <script> const observer = lozad(); observer.observe(); </script>
  1. استفاده از Intersection Observer API
  • این API پیشرفته به شما اجازه می‌دهد تصاویر و عناصر خارج از دید را شناسایی کرده و زمانی که به دید کاربر نزدیک می‌شوند، بارگذاری کنید.
  • نحوه استفاده:
javascript Copy code document.addEventListener("DOMContentLoaded", function () { const images = document.querySelectorAll("img[data-src]"); const observer = new IntersectionObserver((entries, observer) => { entries.forEach(entry => { if (entry.isIntersecting) { const img = entry.target; img.src = img.dataset.src; observer.unobserve(img); } }); }); images.forEach(img => observer.observe(img)); });    

ابزارهایی برای ارزیابی و اجرای Lazy Loading

ابزارهای PageSpeed Insights و Lighthouse گوگل می‌توانند تصاویر خارج از دید را شناسایی کرده و راهکارهای Lazy Loading را پیشنهاد دهند. افزونه‌هایی برای پلتفرم‌هایی مانند وردپرس و Shopify نیز اجرای این تکنیک را برای کاربران غیرمتخصص آسان می‌کنند. با تعویق بارگذاری تصاویر خارج از دید، عملکرد صفحه را بهبود دهید، استفاده از منابع را کاهش دهید و تجربه‌ای سریع‌تر و پاسخ‌گوتر برای کاربران فراهم کنید. این کار نه تنها به بهبود رتبه در موتورهای جستجو کمک می‌کند، بلکه نتایج بهتری در ارزیابی سایت به همراه خواهد داشت.

  • facebook
  • linkedin
  • twitter

خبرنامه

با عضویت در خبرنامه آکادمی کشن، به محض انتشار محتوای جدید، از طریق ایمیل باخبر میشی و به این صورت هیچ مقاله یا آموزشی را از دست نمی دی.