عمومی

رفع مشکل deffer offscreen images به کمک lazyloading

آموزش جی تی متریکس | قسمت ۱۳ – بهینه‌سازی تصاویر بوسیله تکنیک Lazyload

تیم تحریریه سئولب
|
1401:02:12 10:35:44
آموزش جی تی متریکس

Lazy Loading تصاویر چیست؟

Lazy Loading و Eager Loading همیشه در مقابل یکدیگر قرار دارند و خلاف هم هستند. عکس‌ها را اگر به صورت عادی و با همان تگ Img فراخوانی کنید در حالت Eager Load قرار می‌گیرند یعنی به محض بارگزاری صفحه، تمام تصاویری که در صفحه هستند و کاربر هنوز اسکرول را برای دیدن آن‌ها انجام نداده است شروع به Load شدن می‌کنند.

از نظر Lazy Load تصاویری که هنوز در View Port کاربر نیامده است، نیازی به لود شدن ندارند و به محض اینکه کاربر برای دیدن آنها اسکرول را انجام داد برای کاربر نمایش داده شود. همانطور که در تصویر زیر می‌بنید حجم نصف شده است.

گوگل ادعا دارد در کروم ورژن 79 به بعد و در فایرفاکس میتوانید با افزودن Attribiute بنام Loading تصاویر خود را در حالت Lazy قرار دهید.

روش پیاده سازی Lazy Loading

دو روش برای پیاده سازی Lazy Loadnig وجود دارد.

  • استفاده از Attribute بنام Lazy Load که برای خود مرورگر است.
  • استفاده از Js مربوطه که توسط web.dev گوگل معرفی شده است.

سرفصل این مطلب

لیزی لود (Lazy Loading)

هیچ کاربری وبسایت کند را دوست ندارد! اما تصاویر محبوب‌ترین قالب رسانه‌ای در وب هستند. تصاویر یکی از سنگین‌‌‌ترین منابع بارگذاری شده توسط اکثر وبسایت‌هاست و پهنای باند بیشتری را نسبت به سایر دارایی‌ها اشغال می‌کنند. به همین دلیل بهینه سازی تصاویر و توجه به بارگذاری با تأخیر یا لیزی لود (lazy loading)، یک مرحله ضروری برای افزایش سرعت وبسایت است.

با لیزی لود، تنها زمانی می‌توانید تصاویر را بارگذاری کنید که کاربر به سمت تصویر خاص حرکت کند. در راستای آموزش جی تی متریکس، ما می‌خواهیم دربارۀ مفهوم لیزی لود و نحوۀ فعال و غیرفعال کردن آن برای تصاویر و ویدیوها صحبت کنیم.

لیزی لود چیست و چگونه کار می‌کند؟

لیزی لود یا لود تنبل به معنای بارگیری تصاویر در سایت به صورت غیر همزمان (در زمان‌های مختلف) است. به طور خلاصه، نحوه کارکرد لیزی لود به شرح زیر است:

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

لیزی لود در تلفن همراه چگونه است؟

لیزی لود تصویر بومی چیست؟

لیزی لود تصویر بومی (Native Image Lazy Loading) فنآوری جدیدی است که به مرورگرهای کروم اجازه می‌دهد تا لیزی لود را به تنهایی و بدون استفاده از راهنمای جاوا اسکریپت مدیریت کنند.

به عبارت دیگر، مرورگر به طور خودکار تصویری که دارای نشانه گذاری خاص loading = lazy است را بارگذاری می‌کند. این کار بدون شک برای عملکرد وب مفید است زیرا همه وبسایت‌هایی که از نسخه‌های سازگار کروم بازدید می‌کنند، به طور خودکار از لیزی لود سود خواهند برد.

لیزی لود تصویر بومی چگونه کار می‌کند؟

ویژگی بارگیری HTML از سه مقدار زیر پشتیبانی می‌کند:

  • Lazy:

    لود عناصر تصویر یا Iframe را تا زمانی که برخی شرایط را برآورده کند، به تعویق میندازد. این شرایط بسته به عوامل متعددی مانند فرمت تصویر، مرورگر و قدرت اتصال شبکه می‌تواند متفاوت باشد.
  • Eager:

    منابع را فوراً بارگذاری می‌کند، صرف نظر از جایی که در صفحه وب قرار دارند.
  • Auto:

    اگر هیچ مقداری را مشخص نکنید، مقدار پیش فرض ویژگی بارگذاری خودکار است که به مرورگر اجازه می‌دهد تا رفتار پیش فرض لیزی لود را تعیین کند.

لیزی لود چه مزایایی دارد؟

چندین مزیت استفاده از لیزی لود وجود دارند که به شرح زیر هستند:

  1. استفاده از پشتیبانی بومی برای لیزی لود تصاویر باعث می‌شود که عملکرد سایت خود را بسیار آسان کنید.
  2. برای فعال کردن قابلیت لیزی لود در سایت خود، نیازی به نصب کتابخانه‌های جاوا اسکریپت خارجی مانند Jquery ندارید. هرچه منابع شخص ثالث کمتری (Third-Party) لود شوند، عملکرد بهتری دارد.
  3. ایجاد قابلیت لیزی لود به عنوان بخشی از استاندارد HTML، اطمینان می‌دهد که در تمام مرورگرهای اصلی بدون نقص کار خواهد کرد.
  4. صرفه جویی در داده‌ها و هزینه‌های پهنای باند برای کاربران و صاحبان وبسایت بهبود یافته است.

پشتیبانی و سازگاری لیزی لود به چه صورت است؟

ویژگی بارگذاری توسط مرورگرهایی که بیش از 72 درصد از مخاطبان جهانی اینترنت از آن استفاده می‌کنند، پشتیبانی می‌شود. به طور خاص، لیزی لود بومی ‌توسط گوگل کروم و اُپرا پشتیبانی می‌شود. با Chrome 77 گوگل امکان استفاده از ویژگی لود جدید برای منابع لیزی لود را اجرا کرد.

دو مرورگر اصلی در حال حاضر مرورگرهای سفری و iOS سفری هستند که بیش از 15 درصد از کاربران آنلاین از هر دو آنها استفاده می‌کنند. مرورگرهایی که از ویژگی لود پشتیبانی نمی‌کنند مزایای لیزی لود را مشاهده نخواهند کرد اما افزودن ویژگی loading= lazy در کد شما هیچ تاثیری منفی بر عملکرد سایتتان نخواهد داشت.

تصویر لیزی در وردپرس 5.5 چگونه است؟

معرفی API لیزی لود بومی وردپرس سال‌هاست که در میان طرفداران وردپرس بحثی مداوم است. معرفی ویژگی بارگذاری HTML بومی و پشتیبانی نهایی آن توسط مرورگرهای اصلی، این امر را تغییر داد. چند ماه بعد، تیم توسعه هسته وردپرس تصاویر لیزی لود بومی را در وردپرس 5.5 اعلام کردند.

چگونه لیزی لود در وردپرس پیاده سازی می‌شود؟

وردپرس 5.5 جفت ویژگی loading=lazy را به هر تصویری با ویژگی‌های عرضی و ارتفاعی که قبلاً مشخص شده است، اضافه می‌کند. این شرایط برای اجتناب از Cumulative Layout Shift (CLS) گنجانده شده است. این مهم زمانی است که طراحی صفحه وب به طور ناگهانی تغییر می‌کند و یک تجربه کاربری ناخوشآیند را ایجاد می‌کنند.

گوگل بر اساس نمره CLS وب سایت‌ها را رتبه بندی می‌کند. کسانی که رتبه ضعیفی دارند، در نتایج جستجو توسط گوگل جریمه می‌شوند. از نظر فنی، ویژگی لیزی لود بومی وردپرس شبیه به نحوه مدیریت تصاویر پاسخگو با افزودن ویژگی‌های srcset و اندازه عمل می‌کند.

به طور پیش فرض، وردپرس ویژگی loading=lazy را به همۀ برچسب‌های تصویر در خروجی توابع زیر اضافه می‌کند:

  • the_content () تصاویر موجود در محتوای پست
  • the_excerpt () تصاویر موجود در گزیده‌های پست
  • widget_text_content () تصاویر موجود در ابزارک‌های متنی
  • get_avatar () تصاویر آواتار
  • wp_get_attachment_image () تصاویر اضافه شده به عنوان پیوست در وردپرس

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

در زیر لیستی از همۀ آنها با شرح مختصری از کارشان ذکر شده‌اند:

سفارشی کردن لیزی لود در وردپرس

می‌توانید رفتار پیش فرض لیزی لود تصویر بومی را در وردپرس از طریق فیلترهای مختلف سفارشی کنید:

  • مهم‌‌‌ترین آنها فیلتر wp_lazy_loading_enabled است که سه پارامتر را برای سفارشی سازی $ default ، $ tag_name و $ contextمی‌پذیرند. می‌توانید به این فیلتر متصل شوید و لیزی لود را برای همه تصاویر قالب خاموش کنید.
  • برای زمینه‌هایی که تصاویر کاملاً خروجی دارند به عنوان مثال wp_get_attachment_image ()، می‌توانید $ attr آن را مستقیماً با استفاده از PHP تغییر دهید.

تیم اصلی وردپرس چند نمونه سفارشی سازی لیزی لود را منتشر کرده‌اند تا به شما کمک کنند با تمام ویژگی‌های آن آشنا شوید. اگر شما یک قالب وردپرس یا توسعه دهنده افزونه هستید، به شما توصیه می‌کنیم که آنها را ببینید. در حال حاضر، وردپرس از قابلیت لیزی لود بومی ‌فقط برای تصاویر پشتیبانی می‌کند؛ اما ممکن است در آینده آن را به سایر عناصر HTML (به عنوان مثال ، iframes) نیز بسط دهد.

چرا لیزی لود کار نمی‌کند؟

همچنین باید در نظر داشته باشید که لیزی لود بومی آستانه‌ای دارد. تصاویر بالای آن آستانه، لود می‌شوند. تصاویر پایین آستانه لیزی لود نخواهند داشت، اگرچه لیزی لود از نظر فنی کار می‌کند.

اگر از WP Rocket استفاده می‌کنید و تصاویر شما لیزی نیستند، مشکل به دلایل زیر است:

  1. تصاویر در یک Stylesheet اضافه می‌شوند.
  2. تصاویر به صورت پویا با یک اسکریپت اضافه می‌شوند.
  3. تصاویر حاوی یکی از ویژگی‌های حذف شده هستند مانند data-src و data-no-lazy (لیست بسیار طولانی است)

نحوه فعال کردن لیزی لود در تصاویر و فیلم‌ها چگونه است؟

گزینه‌های زیادی برای افزودن لیزی لود به سایت شما وجود دارند. می‌توانید لیست ما را از بهترین افزونه‌های لیزی لود برای وردپرس بررسی کنید. اما تاکنون، ساده‌‌‌ترین راه برای افزودن لیزی لود به سایت خود WP Rocket است. استفاده از این افزونه کمتر از یک دقیقه طول می‌کشد تا فعال شود.

سازگاری با WP Rocket LazyLoad

هنگامی که LazyLoad فعال است، لیزی لود تصویر بومی وردپرس را به طور خودکار غیرفعال می‌کند تا از هرگونه تعارض احتمالی جلوگیری شود. شما می‌توانید LazyLoad را به راحتی با رفتن به Settings > WP Rocket > Media panel وردپرس خود فعال کنید.

برخلاف پیاده سازی بومی وردپرس، لیزی لود برای سایر عناصر HTML مانند iframes و فیلم‌ها فعال می‌شود. همچنین اگر تصاویر عناصر HTML را به صورت درون خطی اعمال کنی ، تصاویر پس زمینه را بارگذاری می‌کند. اگر می‌خواهید از تصویر بومی وردپرس به صورت لیزی استفاده کنید، می‌توانید گزینه لیزی لود را در WP Rocket غیرفعال کنید.

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

نحوه فعال کردن لیزی لود با WP Rocket

حتی اگر WP Rocket شامل سازگاری خودکار با مرورگرهای کروم با استفاده از لیزی لود بومی ‌نیست، می‌توانید پشتیبانی از لیزی لود بومی کروم را انتخاب کنید و می‌توانید آن را از طریق افزونه کمکی فعال کنید.

با استفاده از این افزونه کمکی، می‌توانید مطمئن شوید که:

  • همۀ تصاویر شما دارای نشانه گذاری HTML لازم برای استفاده از لیزی لود بومی هستند.
  • مرورگرهای کروم سازگار به طور خودکار از لیزی لود بومی استفاده می‌کنند.
  • بقیه به طور خودکار از لیدی لوزی WP Rocket استفاده خواهند کرد.

شما می‌توانید از سیستم قدرتمند لیزی لود لذت ببرید یا تصمیم بگیرید با لیزی لود بومی کروم پیش بروید.

کلام آخر

اکنون مهمترین اطلاعات مربوط به لیزی لود تصویر برای وردپرس را می‌دانید. شما همچنین درک می‌کنید که چگونه و چرا استفاده از این تکنیک قدرتمند بهینه سازی وب برای افزایش سرعت سایت ضروری است. این مهم می‌تواند در سرعت وبسایت تأثیر بگذارد و در تجربه کاربری و سئو نیز مؤثر باشد. اگر وبسایت وردپرسی دارید، می‌توانید از افزونه ‌های مختلف برای انجام این کار استفاده کنید.

ادامه خواندن در سایت منبع

دیدگاهتان را بنویسید