رفع خطای Avoid chaining critical requests

رفع خطای Avoid chaining critical requests

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

زنجیره درخواست (chaining critical requests) چیست؟

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

چرا باید از زنجیره درخواست‌های بحرانی اجتناب کرد؟

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

چگونه از زنجیره درخواست‌های بحرانی اجتناب کنیم؟

  1. بهینه‌سازی ترتیب بارگذاری منابع: برای جلوگیری از زنجیره درخواست‌های بحرانی، باید اطمینان حاصل کنید که مهم‌ترین منابع (مانند HTML، CSS بحرانی، و جاوااسکریپت) ابتدا بارگذاری شوند. این منابع نباید به منابع دیگری وابسته باشند زیرا این امر باعث تأخیر در بارگذاری صفحه خواهد شد. با اولویت‌دهی به منابع ضروری، می‌توانید اطمینان حاصل کنید که این منابع بحرانی در اولویت بارگذاری قرار می‌گیرند و زمان مسدود شدن صفحه کاهش می‌یابد.
  2. استفاده از بارگذاری غیرهمزمان (Asynchronous) برای جاوااسکریپت: فایل‌های جاوااسکریپت که برای رندر اولیه صفحه ضروری نیستند، باید به‌صورت غیرهمزمان بارگذاری شوند. این اطمینان می‌دهد که مرورگر منتظر بارگذاری جاوااسکریپت نخواهد ماند و می‌تواند به بارگذاری سایر منابع بحرانی بپردازد و از تأخیر غیرضروری جلوگیری کند.
  3. پیش‌بارگذاری منابع کلیدی: پیش‌بارگذاری به شما این امکان را می‌دهد که منابع بحرانی را پیش از نیاز بارگذاری کنید. با استفاده از تگ <link rel="preload"> در بخش <head> HTML، می‌توانید منابع مهمی مانند فونت‌ها، CSS و تصاویر را پیش‌بارگذاری کنید. این کار از تأخیر جلوگیری کرده و اجازه می‌دهد مرورگر این منابع را زودتر از زمان معمول بارگذاری کند.
  4. استفاده از پروتکل HTTP/2 یا HTTP/3: HTTP/2 و HTTP/3 به مرورگرها این امکان را می‌دهند که درخواست‌ها را به صورت موازی از یک اتصال واحد ارسال کنند، که می‌تواند تأثیر زنجیره درخواست‌ها را کاهش دهد. با استفاده از این پروتکل‌ها، منابعی که معمولاً به صورت دنباله‌ای درخواست می‌شوند، می‌توانند به صورت موازی بارگذاری شوند و زمان بارگذاری منابع بحرانی کاهش یابد.
  5. حذف منابع مسدودکننده رندرینگ: منابعی که رندرینگ صفحه را مسدود می‌کنند، مانند CSS و جاوااسکریپت، باید حداقل شوند یا جایی که امکان‌پذیر است، غیرمسدود کننده شوند. با به تعویق انداختن بارگذاری جاوااسکریپت یا CSS غیرضروری تا پس از رندر اولیه، می‌توانید از مسدود کردن رندر جلوگیری کنید و زمان بارگذاری صفحه را کاهش دهید.
  6. بارگذاری تنبل منابع غیرضروری: منابع غیرضروری مانند تصاویر یا اسکریپت‌های اضافی باید به‌صورت تنبل بارگذاری شوند. این به این معناست که این منابع فقط زمانی بارگذاری می‌شوند که واقعاً نیاز باشند (برای مثال، زمانی که در حال نمایش در صفحه هستند)، که تعداد درخواست‌های بحرانی در بارگذاری اولیه صفحه را کاهش می‌دهد.
  7. استفاده از شبکه تحویل محتوا (CDN): با استفاده از CDN، می‌توانید منابع را از مکان‌هایی که جغرافیایی به کاربر نزدیک‌تر هستند، ارائه دهید. این کار زمان بارگذاری را کاهش می‌دهد و تأثیر زنجیره درخواست‌ها را به حداقل می‌رساند.
  8. کاهش تعداد منابع بحرانی: منابعی که برای رندر اولیه ضروری هستند را شناسایی کرده و فایل‌های غیرضروری را حذف کنید. با کاهش تعداد منابعی که باید برای نمایش صفحه بارگذاری شوند، احتمال ایجاد یک زنجیره درخواست بحرانی طولانی کاهش می‌یابد.

ابزارهایی برای تحلیل و بهینه‌سازی زنجیره درخواست‌های بحرانی

  1. Google Lighthouse: Google Lighthouse یک ابزار قدرتمند است که تحلیل‌های دقیقی از عملکرد وب‌سایت ارائه می‌دهد. این ابزار می‌تواند زنجیره درخواست‌های بحرانی را شناسایی کرده و پیشنهاداتی برای بهبود زمان بارگذاری و حذف تأخیرهای زنجیره‌ای ارائه دهد.
  2. Chrome DevTools: بخش Network در Chrome DevTools به شما این امکان را می‌دهد که ترتیب بارگذاری منابع را مشاهده کنید و زنجیره درخواست‌های بحرانی را شناسایی کنید. با استفاده از نمای "Waterfall"، می‌توانید دنباله درخواست‌ها را مشاهده کرده و مشکلاتی را که توسط زنجیره درخواست‌ها ایجاد می‌شود، شناسایی کنید.
  3. WebPageTest: WebPageTest ابزاری مفید برای تحلیل عملکرد وب‌سایت است که اطلاعات دقیقی در مورد بارگذاری منابع و شناسایی مشکلات زنجیره درخواست‌های بحرانی ارائه می‌دهد.

نتیجه‌گیری

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

  • facebook
  • linkedin
  • twitter

خبرنامه

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