مقدمه ای بر فونت های متغیر در وب

مشخصات فونت جدیدی که می تواند اندازه فایل فونت را به میزان قابل توجهی کاهش دهد

در این مقاله به بررسی فونت های متغیر می پردازیم، مزایایی که ارائه می دهند و چگونه می توانیم از آنها در کار خود استفاده کنیم. ابتدا، بیایید نحوه عملکرد تایپوگرافی در وب و نوآوری هایی که فونت های متغیر به ارمغان می آورند را مرور کنیم.

سازگاری مرورگر

از ماه می 2020، فونت های متغیر در اکثر مرورگرها پشتیبانی می شوند. ببینید آیا می توانم از فونت های متغیر استفاده کنم؟ و فالبک ها .

مقدمه

اصطلاحات فونت و فونت معمولاً توسط توسعه دهندگان به جای هم استفاده می شوند. با این حال یک تفاوت وجود دارد: تایپ فیس طرح بصری زیربنایی است که می تواند در بسیاری از فناوری های حروفچینی مختلف وجود داشته باشد، و فونت یکی از این پیاده سازی ها در قالب فایل دیجیتال است. به عبارت دیگر، فونت همان چیزی است که می بینید و فونت همان چیزی است که استفاده می کنید.

مفهوم دیگری که اغلب نادیده گرفته می شود، تمایز بین سبک و خانواده است. استایل یک نوع تایپ تک و خاص مانند Bold Italic است و یک خانواده مجموعه کاملی از سبک ها است.

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

ترکیب نمونه و لیستی از سبک های مختلف خانواده Roboto
سمت چپ: نمونه ای از خانواده تایپ فیس Roboto. راست: سبک های نامگذاری شده در خانواده.

چالش هایی برای طراح و توسعه دهنده

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

طراحان و توسعه دهندگان وب محدودیت های متفاوتی نسبت به طراحان چاپ دارند و یکی از موارد مهم هزینه های پهنای باند طراحی های ما است. این یک نقطه چسبنده برای تجربیات تایپوگرافی غنی‌تر بوده است، زیرا آنها هزینه دارند. با فونت‌های وب سنتی، هر سبکی که در طراحی‌های ما استفاده می‌شود، کاربران را ملزم می‌کند که یک فایل فونت جداگانه را دانلود کنند، که تأخیر و زمان رندر صفحه را افزایش می‌دهد. فقط شامل سبک‌های معمولی و پررنگ، به‌علاوه همتایان مورب آن‌ها، می‌تواند 500 کیلوبایت یا بیشتر از داده‌های فونت باشد. این حتی قبل از اینکه به نحوه رندر کردن فونت ها، الگوهای بازگشتی که باید استفاده کنیم یا عوارض جانبی نامطلوب مانند FOIT و FOUT پرداخته باشیم.

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

آناتومی یک فونت متغیر

فونت های متغیر با بسته بندی سبک ها در یک فایل واحد، این چالش ها را برطرف می کنند.

این کار با شروع با سبک مرکزی یا «پیش‌فرض»، معمولاً «منظم» - یک طرح رومی راست با معمول‌ترین وزن و عرض که برای متن ساده مناسب‌ترین است، کار می‌کند. سپس این به سبک های دیگر در یک محدوده پیوسته متصل می شود که "محور" نامیده می شود. رایج‌ترین محور Weight است که می‌تواند سبک پیش‌فرض را به یک استایل Bold متصل کند. هر سبک فردی را می توان در امتداد یک محور قرار داد و به آن "نمونه" فونت متغیر می گویند. برخی از نمونه‌ها توسط توسعه‌دهنده فونت نام‌گذاری می‌شوند، برای مثال موقعیت محور وزن 600 SemiBold نامیده می‌شود.

فونت متغیر Roboto Flex دارای سه سبک برای محور وزن خود است. استایل Regular در مرکز قرار دارد و دو استایل در طرف مقابل محور وجود دارد، یکی سبک‌تر و دیگری سنگین‌تر. از بین این موارد، می توانید از 900 نمونه انتخاب کنید:

حرف A در وزن های مختلف نشان داده شده است
در بالا: تشریح آناتومی محور وزن برای تایپ فیس Roboto.

توسعه دهنده فونت می تواند مجموعه ای از محورهای مختلف را ارائه دهد. شما می توانید آنها را ترکیب کنید زیرا همه آنها سبک های پیش فرض یکسانی دارند. Roboto دارای سه سبک در یک محور Width است: Regular در مرکز محور قرار دارد و دو سبک باریکتر و گسترده تر در هر انتهای آن قرار دارند. اینها تمام عرضهای سبک Regular را ارائه می دهند و با محور Weight ترکیب می شوند تا تمام عرض ها را برای هر وزن ارائه دهند.

Roboto Flex در ترکیبات تصادفی عرض و وزن

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

حروف کج

نحوه استفاده از حروف کج در فونت های متغیر جالب است، زیرا دو رویکرد متفاوت وجود دارد. تایپ‌فیس‌هایی مانند Helvetica یا Roboto دارای خطوط سازگار درون‌یابی هستند، بنابراین سبک‌های رومی و ایتالیک آن‌ها را می‌توان بین آن‌ها درون یابی کرد و از محور Slant برای رسیدن از رومی به ایتالیایی استفاده کرد.

سایر حروف (مانند گاراموند، باسکرویل یا بودونی) دارای خطوط رومی و ایتالیک هستند که با درون یابی سازگار نیستند. به عنوان مثال، خطوطی که معمولاً حروف کوچک رومی "n" را تعریف می کنند با خطوطی که برای تعریف حروف کوچک ایتالیایی "n" استفاده می شود، مطابقت ندارند. به جای درونیابی یک کانتور به دیگری، محور ایتالیک از خطوط رومی به ایتالیک تغییر می کند.

نمونه ای از محورهای وزن برای حروف چاپی Amstelvar
خطوط "n" آمستلوار در ایتالیک (12 نقطه، وزن منظم، عرض معمولی) و در رومی. تصویر توسط دیوید برلو، طراح تایپ و تایپوگرافی در Font Bureau تهیه شده است.

پس از تغییر به ایتالیک، محورهای در دسترس کاربر باید همان محورهای رومی باشد، همانطور که مجموعه کاراکترها باید یکسان باشد.

قابلیت تعویض گلیف را می توان برای حروف های جداگانه نیز مشاهده کرد و در هر نقطه از فضای طراحی یک فونت متغیر استفاده کرد. به عنوان مثال، طراحی علامت دلار با دو میله عمودی در اندازه های بزرگتر بهترین کار را دارد، اما در اندازه های نقطه کوچکتر، طرحی با تنها یک میله بهتر است. وقتی پیکسل های کمتری برای رندر کردن حروف داریم، طرح دو نوار می تواند ناخوانا شود. برای مبارزه با این، دقیقاً مانند محور ایتالیایی، جایگزینی یک علامت با علامت دیگر می‌تواند در امتداد محور اندازه نوری در نقطه‌ای که طراح نوع تعیین می‌کند، رخ دهد.

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

تعاریف محورها

پنج محور ثبت شده وجود دارد که ویژگی های شناخته شده و قابل پیش بینی فونت را کنترل می کنند: وزن، عرض، اندازه نوری، مایل و مورب. علاوه بر آن ها، یک فونت می تواند حاوی محورهای سفارشی باشد. اینها می‌توانند هر جنبه طراحی فونت را که طراح نوع می‌خواهد کنترل کند: اندازه سری‌ها، طول swash‌ها، ارتفاع ascenders یا اندازه نقطه روی i.

حتی اگر محورها می توانند یک ویژگی را کنترل کنند، ممکن است از مقادیر متفاوتی استفاده کنند. برای مثال، در فونت‌های متغیر Oswald و Hepta Slab تنها یک محور در دسترس است، Weight، اما محدوده‌ها متفاوت هستند – اسوالد همان محدوده قبل از ارتقاء آن به متغیر است، 200 تا 700، اما هپتا اسلب دارای یک محدوده شدید است. وزن خط مو در 1 که تا 900 می رسد.

پنج محور ثبت شده دارای تگ های کوچک 4 کاراکتری هستند که برای تنظیم مقادیر آنها در CSS استفاده می شود:

نام محورها و مقادیر CSS
وزن wght
عرض wdth
شیب slnt
اندازه نوری opsz
حروف کج ital

از آنجایی که توسعه‌دهنده فونت تعریف می‌کند که کدام محورها در یک فونت متغیر موجود هستند و چه مقادیری می‌توانند داشته باشند، ضروری است که بفهمیم هر فونت چه چیزی را ارائه می‌کند. مستندات فونت باید این را ارائه دهد، یا می‌توانید فونت را با استفاده از ابزاری مانند Wakamai Fondue بررسی کنید.

از موارد و مزایا استفاده کنید

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

بیان هیجان انگیز

نمونه گراس توسط مندی مایکل

یک نمونه عالی از بیان هنری در بالا نشان داده شده است، کاوشی در تایپ فیس Decovar توسط مندی مایکل.

می توانید نمونه کار و کد منبع نمونه بالا را در اینجا مشاهده کنید.

انیمیشن

Typeface Zycon، طراحی شده برای انیمیشن توسط David Berlow، طراح تایپ و تایپوگرافی در Font Bureau.

همچنین امکان کاوش شخصیت های متحرک با فونت های متغیر وجود دارد. در بالا نمونه ای از محورهای مختلف استفاده شده با تایپ فیس Zycon است. نمونه انیمیشن زنده را در Axis Praxis ببینید.

Anicons اولین فونت آیکون رنگی متحرک در جهان است که بر اساس نمادهای طراحی متریال طراحی شده است. Anicons آزمایشی است که دو فناوری فونت پیشرفته را ترکیب می کند: فونت های متغیر و فونت های رنگی.

چند نمونه از انیمیشن های شناور از فونت آیکون رنگی Anicon

ظرافت

Amstelvar از قطعات کوچک XTRA در جهت مخالف استفاده می کند تا عرض کلمات یکسان شود

Roboto Flex و Amstelvar مجموعه ای از "محورهای پارامتریک" را ارائه می دهند. در این محورها، حروف به 4 جنبه اساسی شکل تجزیه می شوند: اشکال سیاه یا مثبت، اشکال سفید یا منفی و ابعاد x و y. همانطور که رنگ های اصلی را می توان با هر رنگ دیگری برای تنظیم آن ترکیب کرد، از این 4 جنبه می توان برای تنظیم دقیق هر محور دیگر استفاده کرد.

محور XTRA در Amstelvar به شما امکان می دهد مقدار "سفید" در هر میلی را مطابق با بالا تنظیم کنید. با استفاده از تکه های کوچک XTRA در جهت مخالف، عرض کلمات یکسان می شود.

فونت های متغیر در CSS

در حال بارگیری فایل های فونت متغیر

فونت های متغیر با همان مکانیزم @font-face مانند فونت های وب استاتیک سنتی بارگذاری می شوند، اما با دو پیشرفت جدید:

@font-face {
    font-family: 'Roboto Flex';
    src: url('RobotoFlex-VF.woff2') format('woff2-variations');
    src: url('RobotoFlex-VF.woff2') format('woff2') tech('variations');
    font-weight: 100 1000;
    font-stretch: 25% 151%;
}

1. قالب‌های منبع: ما نمی‌خواهیم مرورگر فونت را دانلود کند اگر از فونت‌های متغیر پشتیبانی نمی‌کند، بنابراین format و توضیحات tech را اضافه می‌کنیم: یک بار در نحو آینده ( format('woff2') tech('variations') )، یک بار در نحو منسوخ شده اما در میان مرورگرها پشتیبانی می شود ( format('woff2-variations') ). اگر مرورگر از فونت های متغیر پشتیبانی کند و از نحو آینده پشتیبانی کند، از اولین اعلان استفاده خواهد کرد. اگر از فونت های متغیر و نحو فعلی پشتیبانی می کند، از اعلان دوم استفاده می کند. هر دو به یک فایل فونت اشاره می کنند.

2. محدوده‌های سبک: متوجه خواهید شد که ما دو مقدار برای font-weight و font-stretch ارائه می‌کنیم. به جای اینکه به مرورگر بگوییم که این فونت چه وزن خاصی را ارائه می دهد (به عنوان مثال font-weight: 500; )، اکنون محدوده وزن های پشتیبانی شده توسط فونت را به آن می دهیم. برای Roboto Flex، محور Weight از 100 تا 1000 متغیر است و CSS مستقیماً محدوده محور را به ویژگی سبک font-weight نگاشت می‌کند. با مشخص کردن محدوده در @font-face ، هر مقدار خارج از این محدوده به نزدیکترین مقدار معتبر "درپوش" می‌شود. محدوده محور Width نیز به همین ترتیب به ویژگی font-stretch نگاشت می شود.

اگر از Google Fonts API استفاده می‌کنید، همه این موارد برطرف خواهد شد. نه تنها CSS حاوی فرمت‌ها و محدوده‌های منبع مناسب است، فونت‌های Google فونت‌های بازگشتی ثابت را نیز در صورت عدم پشتیبانی از فونت‌های متغیر ارسال می‌کند.

استفاده از وزن و عرض

در حال حاضر، محورهایی که می‌توانید با اطمینان از CSS تنظیم کنید، محور wght از طریق font-weight و محور wdth از طریق font-stretch هستند.

به طور سنتی، font-weight به عنوان یک کلمه کلیدی ( light ، bold ) یا به عنوان یک مقدار عددی بین 100 تا 900، در مراحل 100 تنظیم می کنید. با فونت های متغیر، می توانید هر مقداری را در محدوده عرض قلم تنظیم کنید:

.kinda-light {
  font-weight: 125;
}

.super-heavy {
  font-weight: 1000;
}
محور وزن Roboto Flex از حداقل به حداکثر تغییر می کند.

به همین ترتیب، ما می‌توانیم font-stretch با کلمات کلیدی ( condensed ، ultra-expanded ) یا با مقادیر درصد تنظیم کنیم:

.kinda-narrow {
  font-stretch: 33.3%;
}

.super-wide {
  font-stretch: 151%;
}
محور عرض Roboto Flex از حداقل به حداکثر تغییر می کند.

استفاده از حروف کج و مایل

محور ital برای فونت هایی در نظر گرفته شده است که هم دارای سبک معمولی و هم سبک ایتالیک هستند. محور قرار است یک کلید روشن/خاموش باشد: مقدار 0 خاموش است و سبک معمولی را نشان می دهد، مقدار 1 حروف کج را نشان می دهد. برخلاف سایر محورها، هیچ انتقالی وجود ندارد. مقدار 0.5 به شما "نیم مورب" نمی دهد.

محور slnt با حروف کج متفاوت است زیرا سبک جدیدی نیست، بلکه فقط سبک معمولی را کج می کند. به‌طور پیش‌فرض مقدار آن 0 است، که به معنای حروف عمودی پیش‌فرض است. Roboto Flex حداکثر شیب 10- درجه دارد، به این معنی که حروف هنگام رفتن از 0 به -10 به سمت راست متمایل می شوند.

تنظیم این محورها از طریق ویژگی font-style بصری است، اما از آوریل 2020، نحوه انجام دقیقاً این کار هنوز در حال بررسی است. بنابراین در حال حاضر، باید اینها را به عنوان محورهای سفارشی در نظر بگیرید و آنها را از طریق font-variation-settings تنظیم کنید:

i, em, .italic {
    /* Should be font-style: italic; */
    font-variation-settings: 'ital' 1;
}

.slanted {
    /* Should be font-style: oblique 10deg; */
    font-variation-settings: 'slnt' 10;
}
محور شیب Roboto Flex از حداقل به حداکثر تغییر می کند.

استفاده از اندازه های نوری

یک تایپ فیس را می توان بسیار کوچک (یک پاورقی 12 پیکسلی) یا خیلی بزرگ (یک عنوان 80 پیکسلی) ارائه کرد. فونت‌ها می‌توانند با تغییر شکل حروف به این تغییرات اندازه واکنش نشان دهند تا با اندازه آن مطابقت بیشتری داشته باشند. اندازه کوچک ممکن است بدون جزئیات ظریف بهتر باشد، در حالی که اندازه بزرگ ممکن است از جزئیات بیشتر و ضربه های نازک تر بهره مند شود.

حرف "a" در اندازه های نوری مختلف نشان داده شده است
حرف "a" در Roboto Flex در اندازه های مختلف پیکسل، سپس به یک اندازه کوچک شده است، تفاوت در طراحی را نشان می دهد. خودتان آن را در Codepen امتحان کنید

یک ویژگی CSS جدید برای این محور معرفی شده است: font-optical-sizing . به طور پیش‌فرض روی auto تنظیم شده است، که باعث می‌شود مرورگر مقدار محور را بر اساس font-size تنظیم کند. این به این معنی است که مرورگر بهترین اندازه نوری را به صورت خودکار انتخاب می کند، اما اگر می خواهید آن را خاموش کنید، می توانید font-optical-sizing روی none تنظیم کنید.

همچنین می‌توانید یک مقدار سفارشی برای محور opsz تنظیم کنید، اگر عمداً اندازه نوری می‌خواهید که با اندازه فونت مطابقت نداشته باشد. CSS زیر باعث می شود که متن در اندازه بزرگ نمایش داده شود، اما در اندازه نوری که گویی در 8pt چاپ شده است:

.small-yet-large {
  font-size: 100px;
  font-variation-settings: 'opsz' 8;
}

استفاده از محورهای سفارشی

بر خلاف محورهای ثبت شده، محورهای سفارشی به یک ویژگی CSS موجود نگاشت نمی شوند، بنابراین همیشه باید آنها را از طریق font-variation-settings تنظیم کنید. برچسب ها برای محورهای سفارشی همیشه با حروف بزرگ هستند تا آنها را از محورهای ثبت شده متمایز کنید.

Roboto Flex چند محور سفارشی ارائه می دهد و مهمترین آنها Grade ( GRAD ) است. یک محور Grade جالب است زیرا وزن فونت را بدون تغییر عرض تغییر می‌دهد، بنابراین شکست خطوط تغییر نمی‌کند. با بازی با محور Grade، می‌توانید از تغییر در محور Weight که بر عرض کلی تأثیر می‌گذارد، و سپس تغییر به محور Width که بر وزن کلی تأثیر می‌گذارد، کمانچه نزنید.

محور Grade Roboto Flex از حداقل به حداکثر تغییر می کند.

از آنجایی که GRAD یک محور سفارشی است، با محدوده 200- تا 150 در Roboto Flex. ما باید آن را با font-variation-settings بررسی کنیم:

.grade-light {
    font-variation-settings: `GRAD` -200;
}

.grade-normal {
    font-variation-settings: `GRAD` 0;
}

.grade-heavy {
    font-variation-settings: `GRAD` 150;
}

فونت های متغیر در فونت های گوگل

فونت های گوگل کاتالوگ خود را با فونت های متغیر گسترش داده است و مرتباً فونت های جدید اضافه می کند. هدف این رابط در حال حاضر انتخاب نمونه های منفرد از فونت است: شما تغییری را که می خواهید انتخاب کنید، روی "انتخاب این سبک" کلیک کنید و به عنصر <link> اضافه می شود که CSS و فونت ها را از فونت های Google واکشی می کند.

برای استفاده از تمام محورها یا محدوده‌های مقادیر موجود، باید URL را به صورت دستی در Google Fonts API بنویسید . نمای کلی فونت های متغیر همه محورها و مقادیر را فهرست می کند.

ابزار Google Variable Fonts Links همچنین می‌تواند آخرین آدرس‌های اینترنتی را برای فونت‌های متغیر کامل به شما بدهد.

وراثت فونت-تغییر-تنظیمات

در حالی که تمام محورهای ثبت شده به زودی از طریق ویژگی‌های CSS موجود پشتیبانی می‌شوند، در حال حاضر ممکن است لازم باشد به font-variation-settings به عنوان بازگشتی تکیه کنید. و اگر فونت شما دارای محورهای سفارشی است، به font-variation-settings نیز نیاز دارید.

با این حال، در اینجا یک مشکل کوچک با font-variation-settings وجود دارد. هر ویژگی که به صراحت تنظیم نکرده باشید به طور خودکار به حالت پیش فرض خود بازنشانی می شود. مقادیر تنظیم شده قبلی به ارث برده نمی شوند! این بدان معنی است که موارد زیر آنطور که انتظار می رود کار نمی کنند:

<span class="slanted grade-light">
    I should be slanted and have a light grade
</span>

ابتدا مرورگر font-variation-settings: 'slnt' 10 از کلاس .slanted . سپس font-variation-settings: 'GRAD' -200 از کلاس .grade-light . اما با این کار slnt به حالت پیش فرض 0 باز می گردد! نتیجه متنی با درجه سبک خواهد بود، اما مایل نیست.

خوشبختانه، می‌توانیم با استفاده از متغیرهای CSS این مشکل را حل کنیم:

/* Set the default values */
:root {
    --slnt: 0;
    --GRAD: 0;
}

/* Change value for these elements and their children */
.slanted {
    --slnt: 10;
}

.grade-light {
    --grad: -200;
}

.grade-normal {
    --grad: 0;
}

.grade-heavy {
    --grad: 150;
}

/* Apply whatever value is kept in the CSS variables */
.slanted,
.grade-light,
.grade-normal,
.grade-heavy {
    font-variation-settings: 'slnt' var(--slnt), 'GRAD' var(--GRAD);
}

متغیرهای CSS آبشاری می‌شوند، بنابراین اگر یک عنصر (یا یکی از والدین آن) slnt را روی 10 تنظیم کرده باشد، آن مقدار را حفظ می‌کند، حتی اگر GRAD روی چیز دیگری تنظیم کنید. برای توضیح عمیق این تکنیک ، اصلاح وراثت فونت متغیر را ببینید.

توجه داشته باشید که متحرک سازی متغیرهای CSS (با طراحی) کار نمی کند، بنابراین چیزی شبیه به این کار نمی کند:

@keyframes width-animation {
   from { --wdth: 25; }
   to   { --wdth: 151; }
}

این انیمیشن ها باید مستقیماً در font-variation-settings اتفاق بیفتند.

دستاوردهای عملکردی

فونت های متغیر OpenType به ما این امکان را می دهند که چندین گونه از یک خانواده نوع را در یک فایل فونت ذخیره کنیم. Monotype آزمایشی را با ترکیب 12 فونت ورودی برای تولید هشت وزن، در سه عرض، در هر دو سبک ایتالیایی و رومی انجام داد. ذخیره 48 فونت مجزا در یک فایل فونت متغیر به معنای کاهش 88 درصدی اندازه فایل است.

با این حال، اگر از یک فونت مانند Roboto Regular و هیچ چیز دیگری استفاده می‌کنید، اگر بخواهید به فونت متغیر با محورهای زیاد تغییر دهید، ممکن است افزایش خالصی در اندازه فونت مشاهده نکنید. مثل همیشه، این بستگی به مورد استفاده شما دارد.

از طرف دیگر، متحرک کردن فونت بین تنظیمات ممکن است باعث مشکلات عملکرد شود. اگرچه زمانی که پشتیبانی از فونت متغیر در مرورگرها بالغ‌تر شود، این امر بهبود می‌یابد، اما تنها با متحرک کردن فونت‌هایی که در حال حاضر روی صفحه هستند، می‌توان مشکل را تا حدودی کاهش داد. این قطعه مفید توسط دینامو، انیمیشن‌ها را در عناصر کلاس vf-animation در زمانی که روی صفحه نمایش نیستند، متوقف می‌کند:

var observer = new IntersectionObserver(function(entries, observer) {
  entries.forEach(function(entry) {
    // Pause/Play the animation
    if (entry.isIntersecting) entry.target.style.animationPlayState = "running"
    else entry.target.style.animationPlayState = "paused"
  });
});

var variableTexts = document.querySelectorAll(".vf-animation");
variableTexts.forEach(function(el) { observer.observe(el); });

اگر فونت شما به تعامل کاربر پاسخ می دهد، ایده خوبی است که رویدادهای ورودی را دریچه گاز یا بازگردانی کنید . این کار باعث می‌شود که مرورگر نمونه‌هایی از فونت متغیر را ارائه نکند که نسبت به نمونه قبلی آنقدر تغییر کرده است که چشم انسان تفاوت را نمی‌بیند.

اگر از فونت‌های Google استفاده می‌کنید، بهتر است از قبل به https://fonts.gstatic.com ، دامنه‌ای که فونت‌های Google در آن میزبانی می‌شوند، متصل شوید. این اطمینان حاصل می کند که مرورگر در هنگام برخورد با فونت ها در CSS به زودی می داند که از کجا می تواند فونت ها را دریافت کند:

<link rel="preconnect" href="https://fonts.gstatic.com" />

این نکته برای CDN های دیگر نیز کار می کند: هر چه زودتر به مرورگر اجازه دهید یک اتصال شبکه را راه اندازی کند، زودتر می تواند فونت های شما را دانلود کند.

نکات عملکردی بیشتری برای بارگیری فونت‌های Google در سریع‌ترین فونت‌های Google بیابید.

بازگشت به عقب و پشتیبانی از مرورگر

همه مرورگرهای مدرن از فونت های متغیر پشتیبانی می کنند . در صورتی که نیاز به پشتیبانی از مرورگرهای قدیمی دارید، می‌توانید سایت خود را با فونت‌های ثابت بسازید و از فونت‌های متغیر به عنوان بهبود پیشرونده استفاده کنید:

/* Set up Roboto for old browsers, only regular + bold */
@supports not (font-variation-settings: normal) {
  @font-face {
    font-family: Roboto;
    src: url('Roboto-Regular.woff2');
    font-weight: normal;
  }

  @font-face {
    font-family: Roboto;
    src: url('Roboto-Bold.woff2');
    font-weight: bold;
  }

  body {
    font-family: Roboto;
  }

  .super-bold {
    font-weight: bold;
  }
}

/* Set up Roboto for modern browsers, all weights */
@supports (font-variation-settings: normal) {
  @font-face {
    font-family: 'Roboto';
    src: url('RobotoFlex-VF.woff2') format('woff2 supports variations'),
         url('RobotoFlex-VF.woff2') format('woff2-variations');
    font-weight: 100 1000;
    font-stretch: 25% 151%;
  }

  .super-bold {
    font-weight: 1000;
  }
}

برای مرورگرهای قدیمی، متن با کلاس .super-bold به صورت پررنگ معمولی نمایش داده می شود، زیرا این تنها فونت پررنگی است که در دسترس داریم. وقتی فونت های متغیر پشتیبانی می شوند، در واقع می توانیم از سنگین ترین وزن 1000 استفاده کنیم.

قانون @supports توسط اینترنت اکسپلورر پشتیبانی نمی‌شود، بنابراین این مرورگر هیچ استایلی را نشان نمی‌دهد. اگر این مشکل است، همیشه می توانید از یکی از هک های oldschool برای هدف قرار دادن مرورگرهای قدیمی مرتبط استفاده کنید.

اگر از Google Fonts API استفاده می‌کنید، فونت‌های مناسب را برای مرورگرهای بازدیدکننده بارگیری می‌کند. فرض کنید فونت Oswald را در محدوده وزنی 200 تا 700 درخواست می کنید، مانند:

<link href="https://fonts.googleapis.com/css2?family=Oswald:wght@200..700&display=swap" rel="stylesheet">

مرورگرهای مدرنی که می‌توانند فونت‌های متغیر را مدیریت کنند، فونت متغیر را دریافت می‌کنند و هر وزنی بین 200 تا 700 در دسترس خواهند داشت. مرورگرهای قدیمی‌تر فونت‌های ثابت جداگانه برای هر وزن دریافت می‌کنند. در این مورد، به این معنی است که آنها 6 فایل فونت را دانلود می کنند: یکی برای وزن 200، یکی برای وزن 300، و غیره.

با تشکر

این مقاله تنها با کمک افراد زیر امکان پذیر شده است:

تصویر قهرمان توسط برونو مارتینز در Unsplash .