در ماژول های قبلی، نحوه بهینه سازی HTML، CSS، جاوا اسکریپت و منابع رسانه را یاد گرفتید. در این ماژول، روش هایی را برای بهینه سازی فونت های وب کشف کنید.
فونت های وب می توانند بر عملکرد صفحه هم در زمان بارگذاری و هم در زمان رندر تأثیر بگذارند. دانلود فایلهای فونت بزرگ ممکن است مدتی طول بکشد و تأثیر منفی بر First Contentful Paint (FCP) بگذارد، در حالی که مقدار نادرست font-display
میتواند باعث تغییرات نامطلوب طرحبندی شود که به تغییر چیدمان تجمعی صفحه (CLS) کمک میکند.
قبل از بحث در مورد بهینه سازی فونت های وب، دانستن اینکه چگونه آنها توسط مرورگر کشف می شوند می تواند مفید باشد، به طوری که می توانید درک کنید که چگونه CSS از بازیابی فونت های وب غیر ضروری در شرایط خاص جلوگیری می کند.
کشف
فونت های وب یک صفحه در یک شیوه نامه با استفاده از اعلان @font-face
تعریف می شوند:
@font-face {
font-family: "Open Sans";
src: url("/fonts/OpenSans-Regular-webfont.woff2") format("woff2");
}
قطعه کد قبلی یک font-family
به نام "Open Sans"
را تعریف می کند و به مرورگر می گوید که منبع فونت وب مربوطه را کجا پیدا کند. برای حفظ پهنای باند، مرورگر فونت وب را دانلود نمی کند تا زمانی که مشخص شود که طرح بندی صفحه فعلی به آن نیاز دارد.
h1 {
font-family: "Open Sans";
}
در قطعه CSS قبلی، مرورگر فایل فونت "Open Sans"
را دانلود می کند، زیرا عنصر <h1>
را در HTML صفحه تجزیه می کند.
preload
اگر اعلانهای @font-face
شما در یک شیوه نامه خارجی تعریف شده باشند، مرورگر تنها پس از دانلود شیت سبک میتواند شروع به دانلود آنها کند. این باعث میشود که فونتهای وب منابع دیر کشف شوند - اما راههایی وجود دارد که به مرورگر کمک میکند فونتهای وب را زودتر کشف کند.
شما می توانید با استفاده از دستورالعمل preload
، درخواست اولیه برای منابع فونت وب را آغاز کنید. دستورالعمل preload
فونت های وب را در زمان بارگذاری صفحه قابل شناسایی می کند و مرورگر بلافاصله شروع به دانلود آنها می کند بدون اینکه منتظر بماند تا بارگیری و تجزیه برگه سبک به پایان برسد. دستورالعمل preload
منتظر نمی ماند تا فونت در صفحه مورد نیاز باشد.
<!-- The `crossorigin` attribute is required for fonts—even
self-hosted ones, as fonts are considered CORS resources. -->
<link rel="preload" as="font" href="/fonts/OpenSans-Regular-webfont.woff2" crossorigin>
اعلانهای درون خطی @font-face
میتوانید با استفاده از عنصر <style>
فونتها را زودتر در حین بارگذاری صفحه با داخل کردن CSS مسدودکننده رندر - از جمله اعلانهای @font-face
- در <head>
HTML خود قابل شناسایی کنید. در این حالت، مرورگر فونتهای وب را زودتر در بارگذاری صفحه کشف میکند، زیرا نیازی به صبر کردن برای دانلود یک برگه سبک خارجی ندارد.
دروننویسی اعلانهای @font-face
نسبت به استفاده از راهنمایی preload
مزیت دارد، زیرا مرورگر فقط فونتهای لازم برای ارائه صفحه فعلی را دانلود میکند. این کار خطر دانلود فونت های استفاده نشده را از بین می برد.
دانلود کنید
پس از کشف فونت های وب و اطمینان از اینکه آنها برای طرح بندی صفحه فعلی مورد نیاز هستند، مرورگر می تواند آنها را دانلود کند. تعداد فونت های وب، رمزگذاری آنها و اندازه فایل آنها می تواند به طور قابل توجهی بر سرعت دانلود و رندر یک فونت وب توسط مرورگر تأثیر بگذارد.
فونت های وب خود را خود میزبانی کنید
فونتهای وب را میتوان از طریق سرویسهای شخص ثالث، مانند فونتهای Google ، ارائه کرد یا میتوان آنها را در مبدا خود میزبانی کرد. هنگام استفاده از یک سرویس شخص ثالث، صفحه وب شما باید قبل از اینکه بتواند فونت های وب مورد نیاز را دانلود کند، یک اتصال به دامنه ارائه دهنده باز کند. این می تواند کشف و دانلود بعدی فونت های وب را به تاخیر بیاندازد.
این سربار را می توان با استفاده از راهنمایی منبع preconnect
کاهش داد. با استفاده از preconnect
، میتوانید به مرورگر بگویید که زودتر از آنچه که مرورگر معمولاً انجام میدهد، یک اتصال به مبدا متقاطع را باز کند:
<link rel="preconnect" href="https://fonts.googleapis.com">
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
قطعه HTML قبلی به مرورگر اشاره می کند که یک اتصال به fonts.googleapis.com
و یک اتصال CORS به fonts.gstatic.com
برقرار کند. برخی از ارائه دهندگان فونت - مانند فونت های گوگل - CSS و منابع فونت را از مبداهای مختلف ارائه می کنند.
شما می توانید نیاز به اتصال شخص ثالث را با میزبانی خودکار فونت های وب خود از بین ببرید. در بیشتر موارد، فونت های وب خود میزبان سریعتر از دانلود آنها از یک منبع متقابل است. اگر قصد دارید فونتهای وب خود میزبانی را داشته باشید، بررسی کنید که سایت شما از شبکه تحویل محتوا (CDN) ، HTTP/2 یا HTTP/3 استفاده میکند و سرصفحههای ذخیرهسازی صحیح را برای فونتهای وب مورد نیاز وبسایت خود تنظیم کنید.
فقط از WOFF2 و WOFF2 استفاده کنید
WOFF2 از پشتیبانی گسترده مرورگر و بهترین فشرده سازی برخوردار است—تا 30 درصد بهتر از WOFF. کاهش حجم فایل منجر به زمان دانلود سریعتر می شود. فرمت WOFF2 اغلب تنها فرمت مورد نیاز برای سازگاری کامل در مرورگرهای مدرن است.
فونت های وب خود را زیر مجموعه قرار دهید
فونت های وب معمولاً شامل طیف گسترده ای از حروف های مختلف است که برای نشان دادن طیف گسترده ای از کاراکترهای مورد استفاده در زبان های مختلف مورد نیاز است. اگر صفحه شما محتوا را فقط به یک زبان ارائه میکند - یا از یک الفبا استفاده میکند - میتوانید اندازه فونتهای وب خود را از طریق زیرمجموعه کاهش دهید. این اغلب با تعیین تعداد یا محدوده ای از نقاط کد یونیکد انجام می شود.
یک زیرمجموعه مجموعه ای کاهش یافته از حروف است که در فایل فونت وب اصلی گنجانده شده است. برای مثال، ممکن است صفحه شما به جای نمایش تمام حروفهای کوتاه، یک زیرمجموعه خاص برای حروف لاتین ارائه کند. بسته به زیر مجموعه مورد نیاز، حذف گلیف ها می تواند اندازه یک فایل فونت را به میزان قابل توجهی کاهش دهد.
برخی از ارائه دهندگان فونت وب - مانند فونت های گوگل - زیر مجموعه ها را به طور خودکار از طریق استفاده از پارامتر رشته پرس و جو ارائه می کنند. برای مثال، URL https://fonts.googleapis.com/css?family=Roboto&subset=latin
یک شیوه نامه با فونت وب Roboto ارائه می دهد که فقط از الفبای لاتین استفاده می کند.
اگر تصمیم گرفته اید فونت های وب خود را خود میزبانی کنید، گام بعدی این است که خودتان آن زیر مجموعه ها را با استفاده از ابزارهایی مانند glyphanger یا subfont تولید و میزبانی کنید.
با این حال، اگر ظرفیت میزبانی خودکار فونتهای وب خود را ندارید، میتوانید فونتهای وب ارائه شده توسط Google Fonts را با تعیین یک پارامتر رشته پرس و جو text
اضافی که فقط حاوی نقاط کد یونیکد لازم برای وبسایت شما باشد، زیرمجموعهبندی کنید. به عنوان مثال، اگر یک فونت وب نمایشگر در سایت خود دارید که فقط به تعداد کمی کاراکتر مورد نیاز برای عبارت "Welcome" نیاز دارد، می توانید آن زیر مجموعه را از طریق فونت گوگل از طریق آدرس اینترنتی زیر درخواست کنید: https://fonts.googleapis.com/css?family=Monoton&text=Welcome
. در صورتی که چنین زیرمجموعههای افراطی میتواند در وبسایت شما مفید باشد، این میتواند مقدار دادههای فونت وب مورد نیاز برای یک فونت را در وبسایت شما به میزان قابل توجهی کاهش دهد.
رندر فونت
پس از اینکه مرورگر یک فونت وب را کشف و دانلود کرد، می توان آن را رندر کرد. بهطور پیشفرض، مرورگر رندر متنی را که از فونت وب استفاده میکند تا زمانی که دانلود شود مسدود میکند. میتوانید رفتار نمایش متن مرورگر را تنظیم کنید، و پیکربندی کنید که چه متنی باید نمایش داده شود – یا نشان داده نشود – تا زمانی که فونت وب به طور کامل با استفاده از ویژگی font-display
CSS بارگیری شود.
block
مقدار پیشفرض برای font-display
block
است. با block
، مرورگر رندر هر متنی را که از فونت وب مشخص شده استفاده میکند، مسدود میکند. مرورگرهای مختلف کمی متفاوت رفتار می کنند. Chromium و Firefox رندر را حداکثر تا 3 ثانیه قبل از استفاده از نسخه بازگشتی مسدود می کنند. سافاری به طور نامحدود مسدود می شود تا زمانی که فونت وب بارگیری شود.
swap
swap
پرکاربردترین مقدار font-display
است . swap
رندر را مسدود نمی کند و متن را بلافاصله قبل از جابجایی در فونت وب مشخص شده به صورت بازگشتی نشان می دهد. این به شما امکان می دهد محتوای خود را بلافاصله بدون منتظر ماندن برای دانلود فونت وب نشان دهید.
با این حال، نقطه ضعف swap
این است که اگر فونت وب و فونت وب مشخص شده در CSS شما از نظر ارتفاع خط، کرنینگ و سایر معیارهای فونت بسیار متفاوت باشد، باعث تغییر طرح بندی می شود. اگر مراقب نباشید که preload
راهنمایی برای بارگیری منبع فونت وب در اسرع وقت استفاده نکنید، یا اگر سایر مقادیر font-display
را در نظر نگیرید، می تواند بر CLS وب سایت شما تأثیر بگذارد.
fallback
مقدار fallback
برای font-display
چیزی شبیه سازش بین block
و swap
است. برخلاف swap
، مرورگر رندر یک فونت را مسدود میکند، اما متن جایگزین را فقط برای مدت زمان بسیار کوتاهی تعویض میکند. با این حال، بر خلاف block
، دوره مسدود کردن بسیار کوتاه است.
استفاده از مقدار fallback
می تواند در شبکه های سریع به خوبی کار کند که در آن، اگر فونت وب به سرعت دانلود شود، فونت وب همان فونتی است که بلافاصله در رندر اولیه صفحه استفاده می شود. با این حال، اگر شبکهها کند باشند، متن بازگشتی ابتدا پس از سپری شدن دوره مسدود کردن دیده میشود و پس از رسیدن فونت وب، جایگزین میشود.
optional
optional
دقیقترین مقدار font-display
است و تنها در صورتی از منبع فونت وب استفاده میکند که ظرف 100 میلیثانیه دانلود شود. اگر یک فونت وب بیشتر از آن زمان برای بارگیری طول بکشد، در صفحه استفاده نمی شود و مرورگر از تایپ برگشتی برای پیمایش فعلی استفاده می کند در حالی که فونت وب در پس زمینه دانلود شده و در حافظه پنهان مرورگر قرار می گیرد.
در نتیجه، پیمایشهای بعدی صفحه میتوانند فوراً از فونت وب استفاده کنند، زیرا قبلاً دانلود شده است. font-display: optional
از تغییر چیدمان که با swap
دیده میشود جلوگیری میکند، اما برخی از کاربران فونت وب را اگر خیلی دیر در پیمایش صفحه اولیه برسد، نمیبینند.
دموی فونت
دانش خود را آزمایش کنید
چه زمانی مرورگر یک منبع فونت وب را دانلود می کند (با فرض اینکه با دستورالعمل preload
واکشی نشده باشد)؟
تنها (و کارآمدترین) قالب لازم برای ارائه فونت های وب به تمام مرورگرهای مدرن چیست؟
بعدی: جاوا اسکریپت با تقسیم کد
با درک درستی از بهینه سازی فونت، اکنون می توانید به ماژول بعدی بروید، که موضوعی را پوشش می دهد که پتانسیل بالایی برای بهبود سرعت بارگذاری اولیه صفحه برای کاربران شما دارد، و آن به تعویق انداختن بارگذاری جاوا اسکریپت از طریق تقسیم کد است. . با انجام این کار، میتوانید پهنای باند و اختلاف CPU را در مرحله راهاندازی یک صفحه تا حد امکان پایین نگه دارید، دورهای که کاربران احتمالاً با آن تعامل دارند.