استخراج CSS حیاتی

یاد بگیرید که چگونه زمان‌های رندر را با تکنیک بحرانی CSS بهبود دهید.

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

تصویری از یک لپ‌تاپ و یک دستگاه تلفن همراه با صفحات وب که لبه‌های صفحه‌نمایش را فرا گرفته است

درون‌سازی سبک‌های استخراج‌شده در <head> سند HTML، نیاز به درخواست اضافی برای واکشی این سبک‌ها را از بین می‌برد. باقیمانده CSS را می توان به صورت ناهمزمان بارگذاری کرد.

فایل HTML با CSS حیاتی که در سر قرار دارد
CSS بحرانی خطی

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

مقایسه نمایش نوار فیلم از بارگیری صفحه با CSS مسدودکننده رندر (بالا) و همان صفحه با CSS بحرانی خطی (پایین) در اتصال 3G. نوار فیلم بالا شش فریم خالی را قبل از نمایش محتوا نشان می دهد. نوار فیلم پایین محتوای معنی‌داری را در فریم اول نمایش می‌دهد.
مقایسه بارگیری یک صفحه با CSS مسدودکننده رندر (بالا) و همان صفحه با CSS بحرانی خطی (پایین) در اتصال 3G

اگر First Contentful Paint (FCP) ضعیفی دارید و فرصت «حذف منبع مسدودکننده رندر» را در ممیزی های Lighthouse مشاهده می کنید، ایده خوبی است که CSS حیاتی را امتحان کنید.

ممیزی فانوس دریایی با «حذف منبع مسدودکننده رندر» یا «به تعویق انداختن فرصت‌های CSS استفاده نشده»

برای به حداقل رساندن تعداد دفعات رفت و برگشت تا اولین رندر، سعی کنید محتوای بالای صفحه را زیر 14 کیلوبایت (فشرده) نگه دارید.

تاثیر عملکردی که می توانید با این تکنیک به دست آورید به نوع وب سایت شما بستگی دارد. به طور کلی، هر چه یک سایت دارای CSS بیشتری باشد، تأثیر احتمالی CSS درون‌خطی بیشتر خواهد بود.

مروری بر ابزار

تعدادی ابزار عالی وجود دارد که می تواند به طور خودکار CSS حیاتی یک صفحه را تعیین کند. این خبر خوبی است زیرا انجام این کار به صورت دستی یک فرآیند خسته کننده خواهد بود. برای تعیین سبک هایی که برای هر عنصر در viewport اعمال می شود، نیاز به تجزیه و تحلیل کل DOM است.

انتقادی

بحرانی CSS را استخراج، کوچک‌سازی و خط‌بندی می‌کند و به‌عنوان ماژول npm در دسترس است. می توان آن را با Gulp (مستقیم) یا با Grunt (به عنوان یک افزونه ) استفاده کرد و یک افزونه webpack نیز وجود دارد.

این یک ابزار ساده است که فکر کردن زیادی را از فرآیند خارج می کند. شما حتی نیازی به تعیین شیوه نامه ها ندارید، Critical به طور خودکار آنها را شناسایی می کند. همچنین از استخراج CSS حیاتی برای وضوح صفحه نمایش چندگانه پشتیبانی می کند.

بحرانی CSS

CriticalCSS یکی دیگر از ماژول‌های npm است که CSSهای بالا را استخراج می‌کند. به صورت CLI نیز موجود است.

گزینه‌هایی برای درون‌سازی و کوچک‌سازی CSS حیاتی ندارد، اما به شما اجازه می‌دهد قوانینی را که در واقع به CSS حیاتی تعلق ندارند را اجباری اضافه کنید و به شما کنترل دقیق‌تری بر از جمله اعلان‌های @font-face می‌دهد.

پنت هاوس

پنت هاوس انتخاب خوبی است اگر سایت یا برنامه شما دارای تعداد زیادی سبک یا سبک باشد که به صورت پویا به DOM تزریق می شوند (معمولا در برنامه های Angular). از Puppeteer در زیر کاپوت استفاده می کند و حتی یک نسخه میزبان آنلاین نیز دارد.

پنت هاوس به طور خودکار شیوه نامه ها را شناسایی نمی کند، شما باید فایل های HTML و CSS را که می خواهید CSS حیاتی برای آنها تولید کنید، مشخص کنید. نکته مثبت این است که در اجرای موازی بسیاری از مشاغل خوب است.