Praktik terbaik untuk font

Mengoptimalkan font web untuk Core Web Vitals.

Artikel ini membahas praktik terbaik performa untuk font. Ada berbagai cara font web memengaruhi kinerja:

Artikel ini dibagi menjadi tiga bagian: pemuatan font, pengiriman font, dan rendering font. Setiap bagian menjelaskan cara kerja aspek tertentu dari siklus proses font dan memberikan praktik terbaik yang sesuai.

Pemuatan font

Font biasanya merupakan sumber daya penting, karena tanpa font tersebut, pengguna mungkin tidak dapat melihat konten halaman. Oleh karena itu, praktik terbaik untuk pemuatan font umumnya berfokus untuk memastikan font dimuat sedini mungkin. Anda harus sangat berhati-hati saat menggunakan font yang dimuat dari situs pihak ketiga karena mendownload file font ini memerlukan penyiapan koneksi terpisah.

Jika tidak yakin apakah font halaman diminta tepat waktu, periksa tab Waktu dalam panel Jaringan di Chrome DevTools untuk informasi selengkapnya.

Screenshot tab Waktu di DevTools

Memahami @font-face

Sebelum mendalami praktik terbaik untuk pemuatan font, penting untuk memahami cara kerja @font-face dan bagaimana hal ini memengaruhi pemuatan font.

Deklarasi @font-face adalah bagian penting saat menggunakan font web apa pun. Setidaknya, ini mendeklarasikan nama yang akan digunakan untuk merujuk ke {i>font<i} dan menunjukkan lokasi file {i>font<i} yang sesuai.

@font-face {
  font-family: "Open Sans";
  src: url("/fonts/OpenSans-Regular-webfont.woff2") format("woff2");
}

Kesalahpahaman yang umum adalah font diminta saat deklarasi @font-face ditemukan—ini tidak benar. Dengan sendirinya, deklarasi @font-face tidak memicu download font. Sebaliknya, font hanya akan didownload jika direferensikan oleh gaya yang digunakan di halaman. Misalnya, seperti ini:

@font-face {
  font-family: "Open Sans";
  src: url("/fonts/OpenSans-Regular-webfont.woff2") format("woff2");
}

h1 {
  font-family: "Open Sans"
}

Dengan kata lain, dalam contoh di atas, Open Sans hanya akan didownload jika halaman berisi elemen <h1>.

Oleh karena itu, ketika mempertimbangkan pengoptimalan font, penting untuk mempertimbangkan stylesheet yang sama pentingnya dengan file font itu sendiri. Mengubah konten atau pengiriman stylesheet dapat berdampak signifikan pada kapan font muncul. Demikian pula, menghapus CSS yang tidak digunakan dan memisahkan stylesheet dapat mengurangi jumlah font yang dimuat oleh sebuah halaman.

Deklarasi font inline

Sebagian besar situs akan mendapatkan manfaat besar dari menyisipkan deklarasi font dan gaya visual penting lainnya di <head> dokumen utama, daripada menyertakannya dalam stylesheet eksternal. Hal ini memungkinkan browser menemukan deklarasi font lebih cepat karena browser tidak perlu menunggu stylesheet eksternal didownload.

<head>
  <style>
    @font-face {
        font-family: "Open Sans";
        src: url("/fonts/OpenSans-Regular-webfont.woff2") format("woff2");
    }

    body {
        font-family: "Open Sans";
    }

    ...etc.

  </style>
</head>

Penyelarasan CSS penting dapat menjadi teknik yang lebih canggih yang tidak dapat dicapai oleh semua situs. Manfaat performanya jelas, tetapi memerlukan proses dan alat build tambahan untuk memastikan bahwa CSS—dan idealnya hanya CSS penting—dimasukkan dengan benar dan bahwa setiap CSS tambahan dikirimkan dengan cara yang tidak memblokir perenderan.

Melakukan prakoneksi ke origin pihak ketiga yang penting

Jika situs Anda memuat font dari situs pihak ketiga, sebaiknya gunakan petunjuk referensi preconnect untuk membuat koneksi awal dengan origin pihak ketiga. Petunjuk resource harus ditempatkan di <head> dokumen. Petunjuk resource di bawah akan menyiapkan koneksi untuk memuat stylesheet font.

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

Untuk melakukan prakoneksi pada koneksi yang digunakan untuk mendownload file font, tambahkan petunjuk resource preconnect terpisah yang menggunakan atribut crossorigin. Tidak seperti stylesheet, file font harus dikirim melalui koneksi CORS.

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

Saat menggunakan petunjuk resource preconnect, perlu diingat bahwa penyedia font dapat menayangkan stylesheet dan font dari asal yang terpisah. Misalnya, ini adalah cara penggunaan petunjuk resource preconnect untuk Google Fonts.

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

Hati-hati saat menggunakan preload untuk memuat font

Meskipun preload sangat efektif dalam membuat font dapat ditemukan di awal proses pemuatan halaman, hal ini dapat mengurangi resource browser dari pemuatan resource lainnya.

Menyejajarkan deklarasi font dan menyesuaikan stylesheet mungkin merupakan pendekatan yang lebih efektif. Penyesuaian ini lebih dekat untuk mengatasi akar penyebab font yang terlambat ditemukan — bukan hanya memberikan solusi.

Selain itu, menggunakan preload sebagai strategi pemuatan font juga harus digunakan dengan hati-hati karena metode ini mengabaikan beberapa strategi negosiasi konten bawaan browser. Misalnya, preload mengabaikan deklarasi unicode-range, dan jika digunakan dengan hati-hati, hanya boleh digunakan untuk memuat format font tunggal.

Namun, ketika menggunakan stylesheet eksternal, melakukan pramuat font yang paling penting bisa menjadi sangat efektif karena browser tidak akan menemukan apakah font diperlukan sampai nanti.

Pengiriman font

Pengiriman font yang lebih cepat menghasilkan rendering teks yang lebih cepat. Selain itu, jika {i>font<i} dikirimkan cukup awal, ini bisa membantu menghilangkan pergeseran tata letak yang diakibatkan oleh pertukaran {i>font<i}.

Menggunakan font yang dihosting sendiri

Di kertas, penggunaan font yang dihosting sendiri akan memberikan performa yang lebih baik karena menghilangkan penyiapan koneksi pihak ketiga. Namun, dalam praktiknya, perbedaan performa antara kedua opsi ini kurang jelas: misalnya, Web Almanac menemukan bahwa situs yang menggunakan font pihak ketiga memiliki rendering yang lebih cepat daripada font yang menggunakan font pihak pertama.

Jika Anda mempertimbangkan untuk menggunakan font yang dihosting sendiri, pastikan bahwa situs Anda menggunakan Jaringan Penayangan Konten (CDN) dan HTTP/2. Tanpa penggunaan teknologi ini, kecil kemungkinan font yang dihosting sendiri akan memberikan performa yang lebih baik. Untuk informasi selengkapnya, lihat Jaringan Penayangan Konten.

Jika Anda menggunakan font yang dihosting sendiri, sebaiknya Anda juga menerapkan beberapa pengoptimalan file font yang biasanya disediakan oleh penyedia font pihak ketiga secara otomatis—misalnya, subsetelan font dan kompresi WOFF2. Jumlah upaya yang diperlukan untuk menerapkan pengoptimalan ini akan sedikit bergantung pada bahasa yang didukung situs Anda. Secara khusus, perlu diketahui bahwa mengoptimalkan font untuk bahasa CJK bisa sangat sulit.

Gunakan WOFF2

Di antara font font modern, WOFF2 adalah yang terbaru, memiliki dukungan browser terluas, dan menawarkan kompresi terbaik. Karena menggunakan Brotli, WOFF2 mengompresi 30% lebih baik daripada WOFF, menyebabkan lebih sedikit data yang diunduh dan karenanya kinerja yang lebih cepat.

Mengingat dukungan browser, para pakar sekarang merekomendasikan untuk hanya menggunakan WOFF2:

Bahkan, kami pikir sudah waktunya untuk menyatakan: Gunakan WOFF2 saja dan lupakan hal-hal lainnya.

Hal ini akan menyederhanakan CSS dan alur kerja Anda secara besar-besaran dan juga mencegah download font ganda atau salah yang tidak disengaja. WOFF2 sekarang didukung di mana saja. Jadi, kecuali Anda perlu mendukung {i>browser<i} yang sangat kuno, cukup gunakan WOFF2. Jika tidak bisa, pertimbangkan untuk tidak menyediakan font web di browser-browser lama tersebut. Hal ini tidak akan menjadi masalah jika Anda memiliki strategi penggantian yang kuat. Pengunjung di browser lama hanya akan melihat font penggantian Anda.

Bram Stein, dari Web Almanac 2022

Font subset

File font biasanya mencakup glyph dalam jumlah besar untuk berbagai karakter yang didukung. Namun, Anda mungkin tidak memerlukan semua karakter pada halaman dan dapat mengurangi ukuran file font dengan mengurangi setelan font.

Deskripsi unicode-range di deklarasi @font-face memberi tahu browser tentang karakter mana font dapat digunakan.

@font-face {
    font-family: "Open Sans";
    src: url("/fonts/OpenSans-Regular-webfont.woff2") format("woff2");
    unicode-range: U+0025-00FF;
}

File font akan didownload jika halaman berisi satu atau beberapa karakter yang cocok dengan rentang unicode. unicode-range biasanya digunakan untuk menampilkan file font yang berbeda, bergantung pada bahasa yang digunakan oleh konten halaman.

unicode-range sering digunakan bersamaan dengan teknik subset. Font subset mencakup sebagian kecil glyph yang terdapat dalam file font asli. Misalnya, situs mungkin membuat sebagian font terpisah untuk karakter Latin dan Sirilik, daripada menampilkan semua karakter kepada semua pengguna. Jumlah glyph per font sangat bervariasi: Font Latin biasanya berukuran 100 hingga 1.000 glyph per font; font CJK dapat memiliki lebih dari 10.000 karakter. Menghapus glyph yang tidak digunakan dapat mengurangi ukuran file font secara signifikan.

Beberapa penyedia font mungkin menyediakan file font versi berbeda dengan subset yang berbeda secara otomatis. Misalnya, Google Fonts melakukan hal ini secara default:

/* devanagari */
@font-face {
  font-family: 'Poppins';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/poppins/v20/pxiEyp8kv8JHgFVrJJbecnFHGPezSQ.woff2) format('woff2');
  unicode-range: U+0900-097F, U+1CD0-1CF6, U+1CF8-1CF9, U+200C-200D, U+20A8, U+20B9, U+25CC, U+A830-A839, U+A8E0-A8FB;
}
/* latin-ext */
@font-face {
  font-family: 'Poppins';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/poppins/v20/pxiEyp8kv8JHgFVrJJnecnFHGPezSQ.woff2) format('woff2');
  unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Poppins';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/poppins/v20/pxiEyp8kv8JHgFVrJJfecnFHGPc.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

Saat beralih ke hosting mandiri, ini adalah pengoptimalan yang mudah terlewatkan dan menghasilkan file font yang lebih besar secara lokal.

Anda juga dapat melakukan subset font secara manual jika penyedia font Anda mengizinkannya, baik melalui API (Google Fonts mendukungnya dengan memberikan parameter text), atau dengan mengedit file font secara manual lalu menghosting sendiri. Alat untuk membuat subkumpulan font mencakup subfont dan glyphanger. Namun, periksa lisensi font yang Anda gunakan untuk mengizinkan subset dan menghosting sendiri.

Gunakan lebih sedikit font web

Font tercepat untuk dikirim adalah font yang tidak diminta sejak awal. Font sistem dan font variabel adalah dua cara yang berpotensi mengurangi jumlah font web yang digunakan di situs Anda.

Font sistem adalah font default yang digunakan oleh antarmuka pengguna perangkat pengguna. Font sistem biasanya bervariasi menurut sistem operasi dan versi. Karena font sudah diinstal, font tidak perlu didownload. Font sistem dapat berfungsi sangat baik untuk teks isi.

Untuk menggunakan font sistem di CSS, cantumkan system-ui sebagai jenis font:

font-family: system-ui

Ide di balik font variabel adalah bahwa satu font variabel dapat digunakan sebagai pengganti beberapa file font. Font variabel berfungsi dengan menentukan gaya font "default" dan memberikan "sumbu" untuk memanipulasi font. Misalnya, font variabel dengan sumbu Weight dapat digunakan untuk menerapkan huruf yang sebelumnya memerlukan font terpisah untuk warna terang, reguler, tebal, dan ekstra tebal.

Tidak semua orang akan mendapatkan manfaat dengan beralih ke font variabel. Font variabel memiliki banyak gaya, sehingga biasanya memiliki ukuran file yang lebih besar daripada font non-variabel individual yang hanya berisi satu gaya. Situs yang akan melihat peningkatan terbesar dari penggunaan font variabel adalah situs yang menggunakan (dan perlu menggunakan) berbagai gaya dan ketebalan font.

Rendering font

Saat dihadapkan dengan font web yang belum dimuat, browser dihadapkan dengan dilema: haruskah browser menunda rendering teks hingga font web datang? Atau haruskah merender teks dalam font pengganti hingga font web tiba?

Browser yang berbeda menangani skenario ini secara berbeda. Secara default, browser berbasis Chromium dan Firefox akan memblokir rendering teks hingga 3 detik jika font web yang terkait belum dimuat; Safari akan memblokir rendering teks tanpa batas waktu.

Perilaku ini dapat dikonfigurasi menggunakan atribut font-display. Pilihan ini dapat memiliki implikasi yang signifikan: font-display berpotensi memengaruhi LCP, FCP, dan stabilitas tata letak.

Pilih strategi font-display yang sesuai

font-display memberi tahu browser cara melanjutkan rendering teks saat font web terkait belum dimuat. Ini ditentukan per bentuk font.

@font-face {
  font-family: Roboto, Sans-Serif
  src: url(/fonts/roboto.woff) format('woff'),
  font-display: swap;
}

Ada lima kemungkinan nilai untuk font-display:

Nilai Periode pemblokiran Periode penukaran
Otomatis Bervariasi menurut browser Bervariasi menurut browser
Blok 2–3 detik Tak terbatas
Tukar 0 md Tak terbatas
Pengganti 100 md 3 detik
Opsional 100 md Tidak ada
  • Periode pemblokiran: Periode pemblokiran dimulai saat browser meminta font web. Selama periode pemblokiran, jika font web tidak tersedia, font akan dirender dalam font pengganti yang tidak terlihat sehingga teks tidak akan terlihat oleh pengguna. Jika font tidak tersedia di akhir periode pemblokiran, font akan dirender dalam font pengganti.
  • Periode penukaran: Periode penukaran dilakukan setelah periode pemblokiran. Jika font web tersedia selama periode pertukaran, font web akan "ditukar".

Strategi font-display mencerminkan sudut pandang yang berbeda tentang kompromi antara performa dan estetika. Dengan demikian, sulit untuk memberikan pendekatan yang direkomendasikan karena bergantung pada preferensi individu, seberapa penting font web untuk halaman dan merek, dan seberapa mengganggu font yang terlambat tiba saat ditukar.

Untuk sebagian besar situs, berikut adalah tiga strategi yang paling sesuai:

  • Jika performa menjadi prioritas utama: Gunakan font-display: optional. Ini adalah pendekatan yang paling "berperforma baik": render teks tertunda tidak lebih dari 100 md dan ada jaminan bahwa tidak akan ada pergeseran tata letak terkait pertukaran font. Namun, kekurangannya di sini adalah {i>font<i} web tidak akan digunakan jika {i>font<i} tersebut datang terlambat.

  • Jika prioritas utama Anda adalah menampilkan teks dengan cepat, tetapi Anda ingin tetap memastikan bahwa font web digunakan: Gunakan font-display: swap, tetapi pastikan untuk mengirim font lebih awal agar tidak menyebabkan pergeseran tata letak. Kelemahan dari opsi ini adalah pergeseran yang mengagetkan ketika {i>font<i} terlambat tiba.

  • Jika memastikan bahwa teks ditampilkan dalam font web menjadi prioritas utama: Gunakan font-display: block, tetapi pastikan untuk mengirimkan font cukup awal untuk meminimalkan penundaan teks. Kelemahannya adalah tampilan teks awal akan tertunda. Catatan meskipun deplay ini masih bisa menyebabkan pergeseran tata letak karena teks sebenarnya digambar tidak terlihat, sehingga ruang font pengganti digunakan untuk memesan ruang. Setelah font web dimuat, mungkin diperlukan ruang yang berbeda dan karenanya perlu bergeser. Namun, perubahan ini mungkin tidak terlalu mengagetkan dibandingkan font-display: swap karena teks itu sendiri tidak akan terlihat bergeser.

Perlu diingat juga bahwa kedua pendekatan ini dapat digabungkan: misalnya, gunakan font-display: swap untuk branding dan elemen halaman lain yang unik secara visual; gunakan font-display: optional untuk font yang digunakan dalam teks isi.

Mengurangi peralihan antara font pengganti dan font web Anda

Untuk mengurangi dampak CLS, Anda dapat menggunakan atribut size-adjust baru. Untuk mengetahui informasi selengkapnya, lihat artikel tentang CSS size-adjust. Ini adalah tambahan yang sangat baru untuk rangkaian alat kami, sehingga lebih canggih dan sedikit manual saat ini. Namun yang pasti, Anda harus bereksperimen dan memperhatikan peningkatan alat di masa mendatang.

Kesimpulan

Font web masih menjadi bottleneck kinerja, namun kami memiliki semakin banyak opsi untuk memungkinkan kami mengoptimalkannya guna mengurangi bottleneck ini sebanyak mungkin.