Gaya scroll bar

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.

Dukungan Browser

  • 121
  • 121
  • 64
  • x

Sumber

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.

Ilustrasi bagian-bagian yang membentuk scrollbar.
Ilustrasi bagian-bagian yang membentuk scrollbar. Ilustrasi di sebelah kiri adalah scrollbar minimum yang hanya berisi trek dan thumb. Yang sebelah kanan juga memiliki tombol.

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.

Ilustrasi browser dengan scrollbar overlay.
Ilustrasi browser dengan scrollbar overlay. Scrollbar menempatkan konten; thumb transparan sebagian.

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.

Ilustrasi browser dengan scrollbar klasik.
Ilustrasi browser dengan scrollbar klasik. Scrollbar diposisikan di samping konten di area khususnya sendiri; lebar konten yang tersedia akan diperkecil dibandingkan dengan lebar yang tersedia saat scroll bar overlay digunakan.

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.

Demo: Menata Gaya Scrollbar: scrollbar-color

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.

Demo: Menata Gaya Scrollbar: scrollbar-width

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);
    }
}
Demo: Menata gaya Scrollbar menggunakan scrollbar-* dengan penggantian ke ::-webkit-scrollbar-*

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. */
}
Demo: Menata gaya Scrollbar menggunakan scrollbar-* dengan penggantian ke ::-webkit-scrollbar-*, hanya menerapkan warna ::-webkit-scrollbar-* saat kursor diarahkan