Gunakan properti scrollbar-width
dan scrollbar-color
untuk menata gaya scrollbar.
Pengantar
Dari Chrome versi 2, Anda dapat menata gaya scrollbar dengan elemen pseudo ::-webkit-scrollbar-*
. Pendekatan ini berfungsi dengan baik di Chrome dan Safari, tetapi tidak pernah distandardisasi oleh CSS Working Group.
Yang distandardisasi adalah properti scrollbar-width
dan scrollbar-color
, bagian dari Spesifikasi Modul Penataan Gaya Scrollbars Level 1 CSS. Properti ini didukung mulai Chrome 121.
Scroll bar 101
Anatomi scrollbar
Setidaknya scrollbar terdiri dari track dan thumb. Track adalah area tempat ibu jari dapat digerakkan. Jalur ini mewakili seluruh jarak scroll. Thumbnail mewakili posisi saat ini dalam area yang dapat di-scroll. Saat Anda men-scroll, ikon akan bergerak di dalam trek. thumb juga sering kali dapat ditarik.
Namun, scrollbar dapat memiliki lebih banyak bagian daripada sekadar thumb dan track. Misalnya, scrollbar dapat memiliki satu atau beberapa tombol untuk menambah atau mengurangi offset scroll. Bagian-bagian yang membentuk scrollbar ditentukan oleh sistem operasi yang mendasarinya.
Scrollbar klasik dan overlay
Sebelum melihat cara menata gaya scrollbar, penting untuk memahami perbedaan antara dua jenis scrollbar.
Scrollbar overlay
Scrollbar overlay adalah scrollbar mengambang yang dirender di atas konten di bawahnya. Sub-atribut ini tidak ditampilkan secara default, tetapi hanya saat Anda men-scroll secara aktif. Untuk menjaga agar konten tetap terlihat, mereka sering kali semi-transparan, tetapi itu terserah sistem operasi untuk memutuskan. Saat berinteraksi dengan mereka, ukurannya juga dapat bervariasi.
Scrollbar klasik
Scrollbar klasik adalah scrollbar yang ditempatkan di gutter scrollbar khusus. Gutter scrollbar adalah ruang antara tepi batas dalam dan tepi padding luar. Scrollbar ini biasanya buram (tidak transparan) dan mengurangi ruang dari konten di sebelahnya.
Properti scrollbar-color
dan scrollbar-width
Memberi warna scrollbar dengan scrollbar-color
Properti scrollbar-color
memungkinkan Anda mengubah skema warna scrollbar. Properti ini menerima dua nilai <color>
. Nilai <color>
pertama menentukan warna thumb, dan nilai kedua adalah warna yang digunakan untuk trek.
.scroller {
scrollbar-color: hotpink blue;
}
Saat menggunakan scrollbar overlay, warna trek tidak berpengaruh secara default. Namun, setelah kursor diarahkan ke scrollbar, trek akan muncul.
Untuk menggunakan rendering default yang disediakan oleh sistem operasi, gunakan auto
sebagai nilainya.
Mengubah ukuran scrollbar dengan scrollbar-width
Properti scrollbar-width
memungkinkan Anda memilih scrollbar yang lebih sempit, atau bahkan menyembunyikan scrollbar sepenuhnya tanpa memengaruhi kemampuan scroll.
Nilai yang diterima adalah auto
, thin
, dan none
.
auto
: Lebar scroll bar default seperti yang disediakan oleh platform.thin
: Varian tipis scrollbar yang disediakan oleh platform, atau scrollbar kustom lebih tipis dari scrollbar platform default.none
: Menyembunyikan scrollbar secara efektif. Namun, elemen masih dapat di-scroll.
<length>
seperti 16px
tidak dapat digunakan sebagai nilai untuk scrollbar-width
.
.scroller {
scrollbar-width: thin;
}
Saat menggunakan scrollbar overlay, thumb hanya digambar saat Anda secara aktif men-scroll area yang dapat di-scroll.
Mendukung versi browser lama
Untuk mengakomodasi versi browser yang tidak mendukung scrollbar-color
dan scrollbar-width
, Anda dapat menggunakan properti scrollbar-*
dan ::-webkit-scrollbar-*
yang baru.
.scroller {
--scrollbar-color-thumb: hotpink;
--scrollbar-color-track: blue;
--scrollbar-width: thin;
--scrollbar-width-legacy: 10px;
}
/* Modern browsers with `scrollbar-*` support */
@supports (scrollbar-width: auto) {
.scroller {
scrollbar-color: var(--scrollbar-color-thumb) var(--scrollbar-color-track);
scrollbar-width: var(--scrollbar-width);
}
}
/* Legacy browsers with `::-webkit-scrollbar-*` support */
@supports selector(::-webkit-scrollbar) {
.scroller::-webkit-scrollbar-thumb {
background: var(--scrollbar-color-thumb);
}
.scroller::-webkit-scrollbar-track {
background: var(--scrollbar-color-track);
}
.scroller::-webkit-scrollbar {
max-width: var(--scrollbar-width-legacy);
max-height: var(--scrollbar-width-legacy);
}
}
Perlu diketahui bahwa saat Anda menyetel width
atau height
dari ::-webkit-scrollbar
, scrollbar overlay akan selalu ditampilkan, yang secara efektif mengubahnya menjadi scrollbar klasik.
Untuk mempertahankan ilusi, Anda dapat memilih untuk hanya mengubah warna saat mengarahkan kursor ke scroller.
.scroller::-webkit-scrollbar-thumb {
background: transparent;
}
.scroller::-webkit-scrollbar-track {
background: transparent;
}
.scroller:hover::-webkit-scrollbar-thumb {
background: var(--scrollbar-color-thumb);
}
.scroller:hover::-webkit-scrollbar-track {
background: var(--scrollbar-color-track);
}
.scroller:hover {
--fix: ; /* This custom property invalidates styles on hover, thereby enforcing a style recomputation. This is needed to work around a bug in Safari. */
}