Pengantar font variabel di web

Spesifikasi font baru yang dapat secara signifikan mengurangi ukuran file font

Dalam artikel ini, kita akan melihat apa yang dimaksud dengan font variabel, manfaatnya, dan cara menggunakannya dalam pekerjaan. Pertama, mari kita tinjau cara kerja tipografi di web, dan inovasi yang dibawa font variabel.

Mulai Mei 2020, font variabel didukung di sebagian besar browser. Lihat Dapatkah saya menggunakan font variabel? dan Penggantian.

Pengantar

Istilah {i>font<i} dan jenis huruf sering kali digunakan secara bergantian oleh pengembang. Namun, ada perbedaan: Jenis huruf adalah desain visual yang mendasarinya yang dapat ada dalam berbagai teknologi tata letak, dan font adalah salah satu implementasi ini, dalam format file digital. Dengan kata lain, typeface adalah apa yang Anda lihat, dan font adalah apa yang Anda gunakan.

Konsep lain yang sering diabaikan adalah perbedaan antara gaya dan keluarga. Gaya adalah satu typeface spesifik, seperti Bold Italic, dan keluarga adalah kumpulan lengkap gaya.

Sebelum font variabel, setiap gaya diterapkan sebagai file font terpisah. Dengan font variabel, semua gaya dapat dimuat dalam satu file.

Komposisi spesimen dan daftar berbagai gaya dari keluarga Roboto
Kiri: contoh jenis huruf Roboto. Kanan: gaya bernama dalam keluarga.

Tantangan untuk desainer dan pengembang

Saat membuat project cetak, desainer menghadapi beberapa batasan, seperti ukuran fisik tata letak halaman, jumlah warna yang dapat digunakan (yang ditentukan oleh jenis mesin cetak yang akan digunakan), dan sebagainya. Namun, mereka dapat menggunakan gaya typeface sebanyak yang mereka suka. Ini berarti bahwa tipografi media cetak sering kali kaya dan canggih, sehingga pengalaman membaca benar-benar menyenangkan. Pikirkan terakhir kali Anda menikmati menjelajahi majalah yang bagus.

Desainer dan developer web memiliki batasan yang berbeda dengan desainer cetak, dan yang penting adalah biaya bandwidth terkait dari desain kami. Hal ini telah menjadi masalah bagi pengalaman tipografi yang lebih kaya, karena pengalaman tersebut memerlukan biaya. Dengan font web tradisional, setiap gaya yang digunakan dalam desain kami mengharuskan pengguna untuk mendownload file font terpisah, yang meningkatkan latensi dan waktu rendering halaman. Hanya menyertakan gaya Biasa dan Tebal, beserta gaya miringnya, dapat berjumlah 500 KB atau lebih data font. Hal ini bahkan sebelum kita menangani cara font dirender, pola penggantian yang perlu kita gunakan, atau efek samping yang tidak diinginkan seperti FOIT dan FOUT.

Banyak jenis font menawarkan rentang gaya yang jauh lebih luas, dari tebal Tipis hingga Hitam, lebar sempit dan lebar, berbagai detail gaya, dan bahkan desain khusus ukuran (dioptimalkan untuk ukuran teks besar atau kecil.) Karena Anda harus memuat file font baru untuk setiap gaya (atau kombinasi gaya), banyak developer web memilih untuk tidak menggunakan kemampuan ini, sehingga mengurangi pengalaman membaca pengguna mereka.

Anatomi font variabel

Font variabel mengatasi tantangan ini, dengan memaketkan gaya ke dalam satu file.

Cara ini dilakukan dengan memulai dari gaya tengah atau 'default', biasanya 'Regular'–desain romawi tegak dengan ketebalan dan lebar paling umum yang paling cocok untuk teks biasa. Kemudian, ini terhubung ke gaya lain dalam rentang berkelanjutan, yang disebut 'sumbu'. Sumbu yang paling umum adalah Bobot, yang dapat menghubungkan gaya default ke gaya Tebal. Setiap gaya individual dapat ditempatkan di sepanjang sumbu, dan disebut 'instance' font variabel. Beberapa instance diberi nama oleh developer font, misalnya, lokasi sumbu bobot 600 disebut SemiBold.

Font variabel Roboto Flex memiliki tiga gaya untuk sumbu Bobot. Gaya Reguler berada di tengah, dan ada dua gaya di ujung yang berlawanan dari sumbu, satu lebih terang dan yang lainnya lebih gelap. Di antara keduanya, Anda dapat memilih dari 900 instance:

Huruf &#39;A&#39; yang ditampilkan dalam ketebalan yang berbeda
Di atas: Ilustrasi anatomi sumbu Bobot untuk typeface Roboto.

Developer font dapat menawarkan serangkaian sumbu yang berbeda. Anda dapat menggabungkannya karena memiliki gaya default yang sama. Roboto memiliki tiga gaya dalam sumbu Lebar: Reguler berada di tengah sumbu, dan dua gaya, lebih sempit dan lebih lebar, berada di setiap ujung. Ini memberikan semua lebar gaya Reguler, dan digabungkan dengan sumbu Bobot untuk memberikan semua lebar untuk setiap bobot.

Roboto Flex dalam kombinasi acak Lebar dan Ketebalan

Artinya, ada ribuan gaya! Hal ini mungkin tampak berlebihan, tetapi kualitas pengalaman membaca dapat ditingkatkan secara signifikan dengan keragaman gaya huruf ini. Dan, jika tanpa masalah performa, developer web dapat menggunakan beberapa atau sebanyak mungkin gaya sesuai keinginan mereka.

Miring

Cara penanganan huruf Miring dalam font variabel menarik, karena ada dua pendekatan yang berbeda. Typeface seperti Helvetica atau Roboto memiliki kontur yang kompatibel dengan interpolasi, sehingga gaya Roman dan Miring dapat diinterpolasi di antara dan sumbu Miring dapat digunakan untuk beralih dari Roman ke Miring.

Typeface lainnya (seperti Garamond, Baskerville, atau Bodoni) memiliki kontur glyph Roman dan Miring yang tidak kompatibel dengan interpolasi. Misalnya, kontur yang biasanya menentukan "n" kecil Romawi tidak cocok dengan kontur yang digunakan untuk menentukan "n" kecil Miring. Alih-alih melakukan interpolasi satu kontur ke kontur lainnya, sumbu Italic beralih dari kontur Roman ke Italic.

Contoh Sumbu Berat untuk jenis huruf Amstelvar
Kontur "n" Amstelvar dalam Italic (12 poin, ketebalan reguler, lebar normal), dan dalam Roman. Gambar disediakan oleh David Berlow, desainer dan tipografer font di Font Bureau.

Setelah beralih ke Miring, sumbu yang tersedia untuk pengguna harus sama dengan sumbu untuk Roman, sama seperti kumpulan karakter yang harus sama.

Kemampuan penggantian glyph juga dapat dilihat untuk setiap glyph, dan digunakan di mana saja di ruang desain font variabel. Misalnya, desain tanda dolar dengan dua batang vertikal berfungsi paling baik pada ukuran titik yang lebih besar, tetapi pada ukuran titik yang lebih kecil, desain dengan hanya satu batang akan lebih baik. Jika kita memiliki lebih sedikit piksel untuk merender glyph, desain dua batang dapat menjadi tidak terbaca. Untuk mengatasi hal ini, seperti sumbu Miring, penggantian glyph dari satu glyph ke glyph lain dapat terjadi di sepanjang sumbu Ukuran Optik pada titik yang ditentukan oleh desainer huruf.

Singkatnya, jika kontur memungkinkannya, desainer huruf dapat membuat font yang berinterpolasi antara berbagai gaya dalam ruang desain multi-dimensi. Hal ini memberi Anda kontrol terperinci atas tipografi, dan banyak hal lainnya.

Definisi sumbu

Ada lima sumbu terdaftar, yang mengontrol fitur font yang telah diketahui dan dapat diprediksi: ketebalan, lebar, ukuran optik, miring, dan miring. Selain itu, {i>font<i} dapat berisi sumbu khusus. Hal ini dapat mengontrol aspek desain font yang diinginkan desainer huruf: ukuran serif, panjang goresan, tinggi ascender, atau ukuran titik pada huruf i.

Meskipun sumbu dapat mengontrol fitur yang sama, sumbu tersebut mungkin menggunakan nilai yang berbeda. Misalnya, dalam font variabel Oswald dan Hepta Slab hanya ada satu sumbu yang tersedia, yaitu Bobot, tetapi rentangnya berbeda–Oswald memiliki rentang yang sama seperti sebelum diupgrade menjadi variabel, 200 ke 700, tetapi Hepta Slab memiliki ketebalan garis rambut ekstrem di 1 yang mencapai hingga 900.

Kelima sumbu yang terdaftar memiliki tag huruf kecil 4 karakter yang digunakan untuk menetapkan nilainya di CSS:

Nama sumbu dan nilai CSS
Berat wght
Lebar wdth
Bingung slnt
Ukuran Optik opsz
Miring ital

Karena developer font menentukan sumbu yang tersedia dalam font variabel, dan nilai mana yang dapat dimilikinya, penting untuk mencari tahu apa yang ditawarkan setiap font. Dokumentasi font akan memberikan informasi ini, atau Anda dapat memeriksa font menggunakan alat seperti Wakamai Fondue.

Kasus penggunaan dan manfaat

Menetapkan nilai sumbu bergantung pada selera pribadi dan menerapkan praktik terbaik tipografi. Bahaya dari teknologi baru adalah kemungkinan penyalahgunaan, dan setelan yang terlalu artistik atau eksploratif juga dapat mengurangi keterbacaan teks yang sebenarnya. Untuk judul, menjelajahi berbagai sumbu untuk membuat desain artistik yang bagus memang menarik, tetapi untuk teks isi, hal ini berisiko membuat teks tidak terbaca.

Ekspresi yang menarik

Contoh rumput oleh Mandy Michael

Salah satu contoh ekspresi artistik yang bagus ditampilkan di atas, yaitu eksplorasi font Decovar oleh Mandy Michael.

Anda dapat melihat contoh yang berfungsi dan kode sumber untuk contoh di atas di sini.

Animasi

Jenis huruf Zycon, didesain untuk animasi oleh David Berlow, desainer huruf dan typographer di Font Bureau.

Ada juga kemungkinan untuk mengeksplorasi animasi karakter dengan font variabel. Di atas adalah contoh sumbu yang berbeda yang digunakan dengan typeface Zycon. Lihat contoh animasi langsung pada Sumbu Praksi.

Anicons adalah font ikon warna animasi pertama di dunia, berdasarkan Ikon Desain Material. Anikon adalah eksperimen yang menggabungkan dua teknologi font canggih: font variabel dan font warna.

Beberapa contoh animasi pengarahan kursor dari font ikon warna Anicon

Finesse

Amstelvar menggunakan bit kecil XTRA dalam arah yang berlawanan sehingga lebar kata diratakan

Roboto Flex dan Amstelvar menawarkan serangkaian "Parametric Axes." Pada sumbu ini, huruf didekonstruksi menjadi 4 aspek bentuk fundamental: bentuk hitam atau positif, bentuk putih atau negatif, dan dimensi x dan y. Dengan cara yang sama seperti warna primer dapat dicampur dengan warna lain untuk menyesuaikannya, keempat aspek ini dapat digunakan untuk meningkatkan sumbu lainnya.

Sumbu XTRA di Amstelvar memungkinkan Anda menyesuaikan nilai per mille "putih", seperti yang ditunjukkan di atas. Dengan menggunakan sedikit XTRA dalam arah yang berlawanan, lebar kata akan disamakan.

Font variabel di CSS

Memuat file font variabel

Font variabel dimuat melalui mekanisme @font-face yang sama dengan font web statis tradisional, tetapi dengan dua peningkatan baru:

@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 Sumber: Kita tidak ingin browser mendownload font jika tidak mendukung font variabel, jadi kita menambahkan deskripsi format dan tech: sekali dalam sintaksis mendatang (format('woff2') tech('variations')), sekali dalam sintaksis browser yang tidak digunakan lagi tetapi didukung (format('woff2-variations')). Jika browser mendukung font variabel dan mendukung sintaksis mendatang, browser akan menggunakan deklarasi pertama. Jika mendukung font variabel dan sintaksis saat ini, deklarasi kedua akan digunakan. Keduanya menunjuk ke file font yang sama.

2. Rentang Gaya: Anda akan melihat bahwa kami menyediakan dua nilai untuk font-weight dan font-stretch. Daripada memberi tahu browser ketebalan spesifik yang disediakan font ini (misalnya font-weight: 500;), sekarang kita memberinya rentang ketebalan yang didukung oleh font. Untuk Roboto Flex, sumbu Bobot berkisar dari 100 hingga 1.000, dan CSS secara langsung memetakan rentang sumbu ke properti gaya font-weight. Dengan menentukan rentang di @font-face, nilai apa pun di luar rentang ini akan "dibatasi" ke nilai valid terdekat. Rentang sumbu Lebar dipetakan dengan cara yang sama ke properti font-stretch.

Jika Anda menggunakan Google Fonts API, semua ini akan ditangani. CSS tidak hanya akan berisi format dan rentang sumber yang tepat, Google Fonts juga akan mengirimkan font penggantian statis jika font variabel tidak didukung.

Menggunakan ketebalan dan lebar

Saat ini, sumbu yang dapat Anda tetapkan dengan andal dari CSS adalah sumbu wght melalui font-weight, dan sumbu wdth melalui font-stretch.

Secara tradisional, Anda akan menetapkan font-weight sebagai kata kunci (light, bold) atau sebagai nilai numerik antara 100 dan 900, dengan langkah 100. Dengan font variabel, Anda dapat menetapkan nilai apa pun dalam rentang Lebar font:

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

.super-heavy {
  font-weight: 1000;
}
Sumbu Bobot Roboto Flex diubah dari minimum ke maksimum.

Demikian pula, kita dapat menetapkan font-stretch dengan kata kunci (condensed, ultra-expanded) atau dengan nilai persentase:

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

.super-wide {
  font-stretch: 151%;
}
Sumbu Lebar Roboto Flex diubah dari minimum ke maksimum.

Menggunakan huruf miring dan miring

Sumbu ital ditujukan untuk font yang berisi gaya reguler dan gaya miring. Sumbu dimaksudkan sebagai tombol aktif/nonaktif: nilai 0 nonaktif dan akan menampilkan gaya reguler, nilai 1 akan menampilkan miring. Tidak seperti sumbu lainnya, tidak ada transisi. Nilai 0.5 tidak akan memberi Anda "setengah miring".

Sumbu slnt berbeda dengan miring karena bukan gaya baru, tetapi hanya memiringkan gaya reguler. Secara default, nilainya adalah 0, yang berarti bentuk huruf tegak default. Roboto Flex memiliki kemiringan maksimum -10 derajat, yang berarti huruf miring ke kanan saat beralih dari 0 ke -10.

Akan intuitif untuk menyetel sumbu ini melalui properti font-style, tetapi mulai April 2020, cara tepatnya untuk melakukannya masih diselesaikan. Jadi, untuk saat ini, Anda harus menganggapnya sebagai sumbu kustom, dan menetapkannya melalui 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;
}
Aksis miring Roboto Flex diubah dari minimum ke maksimum.

Menggunakan ukuran optik

Jenis huruf dapat dirender sangat kecil (catatan kaki 12 px) atau sangat besar (judul 80 px). Font dapat merespons perubahan ukuran ini dengan mengubah bentuk hurufnya agar lebih sesuai dengan ukurannya. Ukuran kecil mungkin lebih baik tanpa detail halus, sedangkan ukuran besar mungkin mendapatkan manfaat dari lebih banyak detail dan goresan yang lebih tipis.

Huruf &#39;a&#39; yang ditampilkan dalam berbagai ukuran optik
Huruf 'a' dalam Roboto Flex dengan ukuran piksel yang berbeda, lalu diskalakan menjadi ukuran yang sama, menunjukkan perbedaan dalam desain. Coba sendiri di Codepen

Properti CSS baru telah diperkenalkan untuk sumbu ini: font-optical-sizing. Secara default, atribut ini ditetapkan ke auto, yang membuat browser menetapkan nilai sumbu berdasarkan font-size. Artinya, browser akan memilih ukuran optik terbaik secara otomatis, tetapi jika Anda ingin menonaktifkannya, Anda dapat menetapkan font-optical-sizing ke none.

Anda juga dapat menetapkan nilai kustom untuk sumbu opsz, jika Anda sengaja menginginkan ukuran optik yang tidak cocok dengan ukuran font. CSS berikut akan menyebabkan teks ditampilkan dalam ukuran besar, tetapi dalam ukuran optik seolah-olah dicetak dalam 8pt:

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

Menggunakan sumbu kustom

Tidak seperti sumbu yang terdaftar, sumbu kustom tidak akan dipetakan ke properti CSS yang sudah ada, sehingga Anda harus selalu menetapkannya melalui font-variation-settings. Tag untuk sumbu kustom selalu menggunakan huruf besar, untuk membedakannya dari sumbu terdaftar.

Roboto Flex menawarkan beberapa sumbu kustom, dan yang paling penting adalah Grade (GRAD). Sumbu Grade menarik karena mengubah ketebalan font tanpa mengubah lebar, sehingga akhir baris tidak berubah. Dengan bermain-main dengan sumbu Kelas, Anda dapat menghindari keharusan mengutak-atik perubahan pada sumbu Bobot yang memengaruhi lebar keseluruhan, lalu mengubah sumbu Lebar yang memengaruhi bobot keseluruhan.

Sumbu Nilai Roboto Flex diubah dari minimum ke maksimum.

Karena GRAD adalah sumbu kustom, dengan rentang -200 hingga 150 di Roboto Flex. Kita perlu mengatasinya dengan font-variation-settings:

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

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

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

Font variabel di Google Fonts

Google Fonts telah memperluas katalognya dengan font variabel, dan menambahkan font baru secara rutin. Antarmuka saat ini ditujukan untuk memilih satu instance dari font: Anda memilih variasi yang diinginkan, mengklik "Pilih gaya ini", dan variasi tersebut akan ditambahkan ke elemen <link> yang mengambil CSS dan font dari Google Fonts.

Untuk menggunakan semua sumbu, atau rentang nilai yang tersedia, Anda harus membuat URL secara manual ke Google Fonts API. Ringkasan font variabel mencantumkan semua sumbu dan nilai.

Alat Link Font Variabel Google juga dapat memberi Anda URL terbaru untuk font variabel lengkap.

Pewarisan setelan-variasi-font

Meskipun semua sumbu yang terdaftar akan segera didukung melalui properti CSS yang ada, untuk saat ini Anda mungkin perlu mengandalkan font-variation-settings sebagai penggantian. Dan jika font Anda memiliki sumbu kustom, Anda juga memerlukan font-variation-settings.

Namun, berikut adalah sedikit masalah dengan font-variation-settings. Setiap properti yang Anda tidak tetapkan secara eksplisit akan otomatis direset ke default. Nilai yang ditetapkan sebelumnya tidak diwarisi. Artinya, hal berikut tidak akan berfungsi seperti yang diharapkan:

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

Pertama, browser akan menerapkan font-variation-settings: 'slnt' 10 dari class .slanted. Kemudian, kode akan menerapkan font-variation-settings: 'GRAD' -200 dari class .grade-light. Namun, tindakan ini akan mereset slnt kembali ke defaultnya 0. Hasilnya akan berupa teks dalam nilai ringan, tetapi tidak miring.

Untungnya, kita dapat mengatasi masalah ini dengan menggunakan variabel 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);
}

Variabel CSS akan menurun, sehingga jika elemen (atau salah satu induknya) telah menetapkan slnt ke 10, elemen ini akan mempertahankan nilai tersebut, meskipun Anda menetapkan GRAD ke sesuatu yang lain. Lihat Memperbaiki pewarisan font variabel untuk penjelasan mendalam tentang teknik ini.

Perhatikan bahwa menganimasikan variabel CSS tidak berfungsi (secara desain), sehingga hal seperti ini tidak berfungsi:

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

Animasi ini harus terjadi langsung di font-variation-settings.

Peningkatan performa

Font variabel OpenType memungkinkan kita menyimpan beberapa variasi jenis huruf ke dalam satu file font. Monotype melakukan eksperimen dengan menggabungkan 12 font input untuk menghasilkan delapan ketebalan, di tiga lebar, di seluruh gaya Miring dan Romawi. Menyimpan 48 font individual dalam satu file font variabel berarti pengurangan ukuran file sebesar 88%.

Namun, jika menggunakan font tunggal seperti Roboto Regular dan yang lain, Anda mungkin tidak akan melihat peningkatan bersih dalam ukuran font jika beralih ke font variabel dengan banyak sumbu. Seperti biasa, hal ini bergantung pada kasus penggunaan Anda.

Di sisi lain, menganimasikan font di antara setelan dapat menyebabkan masalah performa. Meskipun hal ini akan meningkat setelah dukungan font variabel di browser menjadi lebih matang, masalahnya dapat dikurangi dengan hanya menganimasikan font yang saat ini ada di layar. Cuplikan praktis dari Dinamo ini menjeda animasi dalam elemen dengan class vf-animation, saat tidak ada di layar:

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); });

Jika font Anda merespons interaksi pengguna, sebaiknya batasi atau jeda peristiwa input. Hal ini akan mencegah browser merender instance font variabel yang berubah sangat sedikit dari instance sebelumnya sehingga mata manusia tidak akan melihat perbedaannya.

Jika Anda menggunakan Google Fonts, sebaiknya prakoneksikan ke https://fonts.gstatic.com, domain tempat font Google dihosting. Tindakan ini akan memastikan browser mengetahui sejak awal tempat mendapatkan font saat menemukannya di CSS:

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

Tips ini juga berlaku untuk CDN lain: semakin cepat Anda mengizinkan browser menyiapkan koneksi jaringan, semakin cepat browser dapat mendownload font Anda.

Temukan tips performa lainnya untuk memuat Google Fonts di Google Fonts Tercepat.

Penggantian dan dukungan browser

Semua browser modern mendukung font variabel. Jika perlu mendukung browser lama, Anda dapat memilih untuk mem-build situs dengan font statis, dan menggunakan font variabel sebagai progressive enhancement:

/* 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;
  }
}

Untuk browser lama, teks dengan class .super-bold akan dirender dalam cetak tebal normal, karena itu satu-satunya font tebal yang tersedia. Jika font variabel didukung, kita sebenarnya dapat menggunakan ketebalan terberat 1.000.

Aturan @supports tidak didukung oleh Internet Explorer, sehingga browser ini tidak akan menampilkan gaya apa pun. Jika ini menjadi masalah, Anda selalu dapat menggunakan salah satu hack lama untuk menargetkan browser lama yang relevan.

Jika Anda menggunakan Google Fonts API, API ini akan memuat font yang tepat untuk browser pengunjung. Misalnya, Anda meminta font Oswald dalam rentang ketebalan 200 hingga 700, seperti ini:

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

Browser modern yang dapat menangani font variabel akan mendapatkan font variabel, dan akan memiliki setiap ketebalan antara 200 dan 700. Browser lama akan menerima font statis individual untuk setiap ketebalan. Dalam hal ini, artinya mereka akan mendownload 6 file font: satu untuk ketebalan 200, satu untuk ketebalan 300, dan sebagainya.

Terima kasih

Artikel ini hanya dapat dibuat dengan bantuan orang-orang berikut:

Gambar hero oleh Bruno Martins di Unsplash.