捲軸樣式

使用 scrollbar-widthscrollbar-color 屬性為捲軸設定樣式。

簡介

自 Chrome 2 版起,您可以使用 ::-webkit-scrollbar-* 疑似元素為捲軸設定樣式。這個方法適用於 Chrome 和 Safari,但 CSS 工作小組並未標準化。

scrollbar-widthscrollbar-color 屬性已完成標準化,屬於 CSS 捲軸樣式模組第 1 級規格的一部分。這些屬性自 Chrome 121 起開始支援。

瀏覽器支援

  • Chrome:121。
  • Edge:121。
  • Firefox:64。
  • Safari:不支援。

資料來源

捲軸入門

捲軸剖析

捲軸至少要包含軌道和指標。軌道是手指可以移動的區域。歷程代表整個捲動距離。拇指代表可捲動區域內的目前位置。捲動時,它會在軌道內移動。拇指通常也可以拖曳。

不過,捲軸列的部分不只限於滑動手勢和軌跡。舉例來說,捲軸可能會有一或多個按鈕,用於增加或減少捲動偏移量。捲軸的組成部分取決於基礎作業系統。

插圖:構成捲軸的部分。
插圖:捲軸的組成部分。左圖是最小的捲軸,只有軌道和指標。右側的圖片也有按鈕。

傳統和疊加式捲軸條

在瞭解如何設定捲軸樣式之前,請先瞭解兩種捲軸的差異。

重疊捲軸

重疊捲軸是浮動捲軸,會在底層內容上方顯示。根據預設,系統不會顯示這些指標,只有在您捲動畫面時才會顯示。為了保持內容底下顯示的內容,通常會以半透明的形式顯示,但作業系統是由作業系統自行決定。在與這些元素互動時,它們的大小也可能會有所不同。

插圖:瀏覽器有重疊的捲動條。
插圖:瀏覽器搭配重疊捲軸。捲軸遮蓋內容,且捲軸手勢半透明。

傳統捲軸

傳統捲軸是放在專用的捲軸溝槽中的捲軸。捲軸溝槽是內框線與外部邊框間距邊緣之間的空間。這些捲軸通常為不透明 (而非透明),會在周圍的內容騰出一定空間。

插圖:瀏覽器使用經典捲動條。
插圖:瀏覽器內含傳統捲軸。捲軸會在內容旁的專屬區域中顯示,且內容的可用寬度會縮減,與使用重疊捲軸時的可用寬度相比。

scrollbar-colorscrollbar-width 屬性

使用 scrollbar-color 為捲動條指定顏色

scrollbar-color 屬性可讓您變更捲軸的色彩配置。這個屬性可接受兩個 <color> 值。第一個 <color> 值會決定縮圖的顏色,第二個則是用於音軌的顏色。

.scroller {
  scrollbar-color: hotpink blue;
}

使用疊加捲軸時,軌跡的顏色預設為無效。不過,只要將滑鼠游標懸停在捲軸上,就會顯示軌跡。

示範:設定捲軸樣式:scrollbar-color

如要使用作業系統提供的預設算繪模式,請將值設為 auto

使用 scrollbar-width 變更捲軸大小

scrollbar-width 屬性可讓您選擇較窄的捲軸,甚至完全隱藏捲軸,而不影響捲動功能。

可接受的值為 autothinnone

  • auto:平台提供的預設捲軸寬度。
  • thin:平台提供的捲軸細變化版本,或比預設平台捲軸更細的自訂捲軸。
  • none:有效隱藏捲軸。不過,元素仍可捲動瀏覽。

您無法使用 <length> (例如 16px) 做為 scrollbar-width 的值。

.scroller {
  scrollbar-width: thin;
}

使用重疊式捲軸時,只有在您主動捲動可捲動區域時,系統才會繪製滑塊。

示範:設定捲軸樣式:scrollbar-width

支援舊版瀏覽器

為了支援不支援 scrollbar-colorscrollbar-width 的瀏覽器版本,您可以同時使用新的 scrollbar-*::-webkit-scrollbar-* 屬性。

.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);
    }
}
示範:使用 scrollbar-* 設定捲軸樣式,並備援 ::-webkit-scrollbar-*

請注意,當您設定 ::-webkit-scrollbarwidthheight 時,系統一律會顯示疊加式捲軸,實際上會將其轉換為傳統捲軸。

為了維持視覺效果,您可以選擇只在游標懸停時變更顏色。

.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. */
}
示範:使用 scrollbar-* 設定捲軸樣式,並備援 ::-webkit-scrollbar-*,僅在游標懸停時套用 ::-webkit-scrollbar-* 顏色