::-webkit-scrollbar

Kein Standard: Diese Funktion ist nicht standardisiert und befindet sich nicht im Standardisierungsprozess. Verwenden Sie sie nicht auf Produktionsseiten, die auf das Web ausgerichtet sind: Sie wird nicht für alle Benutzer funktionieren. Außerdem kann es große Inkompatibilitäten zwischen Implementierungen geben und das Verhalten kann sich in Zukunft ändern.

Das CSS-Pseudo-Element ::-webkit-scrollbar beeinflusst den Stil eines Scrollbalkens eines Elements, wenn dieser überlaufend scrollbar ist.

Die Standard-Eigenschaften scrollbar-color und scrollbar-width können als Alternativen für Browser verwendet werden, die dieses Pseudo-Element und die verwandten ::-webkit-scrollbar-* Pseudo-Elemente nicht unterstützen (siehe Browser-Kompatibilität).

Hinweis: Wenn scrollbar-color und scrollbar-width unterstützt werden und einen anderen Wert als auto haben, überschreiben sie die ::-webkit-scrollbar-* Gestaltung. Siehe Hinzufügen eines Fallbacks für Scrollbalkenstile für weitere Details.

CSS Scrollbar Selektoren

Sie können die folgenden Pseudo-Elemente verwenden, um verschiedene Teile der Scrollleiste für WebKit-Browser anzupassen:

  • ::-webkit-scrollbar — der gesamte Scrollbalken.
  • ::-webkit-scrollbar-button — die Schaltflächen auf der Scrollleiste (Pfeile, die nach oben und unten zeigen und eine Zeile nach der anderen scrollen).
  • ::-webkit-scrollbar:horizontal — der horizontale Scrollbalken.
  • ::-webkit-scrollbar-thumb — der ziehbare Scrollgriff.
  • ::-webkit-scrollbar-track — die Führung (Fortschrittsbalken) des Scrollbalkens, wo sich ein grauer Balken über einem weißen Balken befindet.
  • ::-webkit-scrollbar-track-piece — der Teil der Führung (Fortschrittsbalken), der nicht vom Griff abgedeckt ist.
  • ::-webkit-scrollbar:vertical — der vertikale Scrollbalken.
  • ::-webkit-scrollbar-corner — die untere Ecke des Scrollbalkens, wo sich horizontale und vertikale Scrollbalken treffen. Dies ist oft die untere rechte Ecke des Browserfensters.
  • ::-webkit-resizer — der ziehbare Vergrößerungsgriff, der in der unteren Ecke einiger Elemente erscheint.

Barrierefreiheit

Autoren sollten vermeiden, Scrollbalken zu gestalten, da das Ändern des Erscheinungsbildes von Scrollbalken von der Voreinstellung abweicht und die externe Konsistenz beeinträchtigt, was die Benutzerfreundlichkeit negativ beeinflusst. Wenn Sie Scrollbalken gestalten, stellen Sie sicher, dass genügend Farbkontrast vorhanden ist und die Berührungsziele mindestens 44px breit und hoch sind. Siehe Techniken für WCAG 2.0: G183: Verwenden eines Kontrastverhältnisses von 3:1 und Verständnis von WCAG 2.1 : Zielgröße.

Beispiele

Scrollbalken mit -webkit-scrollbar gestalten

CSS

css
.visible-scrollbar,
.invisible-scrollbar,
.mostly-customized-scrollbar {
  display: block;
  width: 10em;
  overflow: auto;
  height: 2em;
  padding: 1em;
  margin: 1em auto;
  outline: 2px dashed cornflowerblue;
}

.invisible-scrollbar::-webkit-scrollbar {
  display: none;
}

/* Demonstrate a "mostly customized" scrollbar
 * (won't be visible otherwise if width/height is specified) */
.mostly-customized-scrollbar::-webkit-scrollbar {
  width: 5px;
  height: 8px;
  background-color: #aaa; /* or add it to the track */
}

/* Add a thumb */
.mostly-customized-scrollbar::-webkit-scrollbar-thumb {
  background: #000;
}

HTML

html
<div class="visible-scrollbar">
  <h3>Visible scrollbar</h3>
  <p>
    Etiam sagittis sem sed lacus laoreet, eu fermentum eros auctor. Proin at
    nulla elementum, consectetur ex eget, commodo ante. Sed eros mi, bibendum ut
    dignissim et, maximus eget nibh. Phasellus blandit quam turpis, at mollis
    velit pretium ut. Nunc consequat efficitur ultrices. Nullam hendrerit
    posuere est. Nulla libero sapien, egestas ac felis porta, cursus ultricies
    quam. Vestibulum tincidunt accumsan sapien, a fringilla dui semper in.
    Vivamus consectetur ipsum a ornare blandit. Aenean tempus at lorem sit amet
    faucibus. Curabitur nibh justo, faucibus sed velit cursus, mattis cursus
    dolor. Pellentesque id pretium est. Quisque convallis nisi a diam malesuada
    mollis. Aliquam at enim ligula.
  </p>
</div>

<div class="invisible-scrollbar">
  <h3>Invisible scrollbar</h3>
  <p>
    Thisisaveeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeerylongword
  </p>
</div>

<div class="mostly-customized-scrollbar">
  <h3>Custom scrollbar</h3>
  <p>
    Thisisaveeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeerylongword<br />
    And pretty tall<br />
    thing with weird scrollbars.<br />
    Who thought scrollbars could be made weird?
  </p>
</div>

Ergebnis

Hinzufügen eines Fallbacks für Scrollbalkenstile

Sie können eine @supports Regel verwenden, um zu erkennen, ob ein Browser die Standard-Eigenschaften scrollbar-color und scrollbar-width unterstützt und andernfalls ein Fallback mit ::-webkit-scrollbar-* Pseudo-Elementen verwenden. Das folgende Beispiel zeigt, wie man Farben auf Scrollbalken anwendet, indem man scrollbar-color verwendet, falls unterstützt, und ::-webkit-scrollbar-* Pseudo-Elemente, falls nicht.

HTML

html
<div class="scroll-box">
  <h1>Yoshi</h1>
  <p>
    Yoshi is a fictional dinosaur who appears in video games published by
    Nintendo. Yoshi debuted in Super Mario World (1990) on the SNES as Mario and
    Luigi's sidekick.
  </p>
  <p>
    Throughout the mainline Super Mario series, Yoshi typically serves as
    Mario's trusted steed.
  </p>
  <p>
    With a gluttonous appetite, Yoshi can gobble enemies with his long tongue,
    and lay eggs that doubly function as projectiles.
  </p>
</div>

CSS

css
/* For browsers that support `scrollbar-*` properties */
@supports (scrollbar-color: auto) {
  .scroll-box {
    scrollbar-color: aquamarine cornflowerblue;
  }
}

/* Otherwise, use `::-webkit-scrollbar-*` pseudo-elements */
@supports selector(::-webkit-scrollbar) {
  .scroll-box::-webkit-scrollbar {
    background: aquamarine;
  }
  .scroll-box::-webkit-scrollbar-thumb {
    background: cornflowerblue;
  }
}

Ergebnis

Im folgenden Beispiel können Sie die umrandete Box vertikal scrollen, um die Wirkung der Gestaltung des Scrollbalkens zu sehen.

Spezifikationen

Nicht Teil eines Standards.

Browser-Kompatibilität

css.selectors.-webkit-scrollbar

BCD tables only load in the browser

css.selectors.-webkit-scrollbar-button

BCD tables only load in the browser

css.selectors.-webkit-scrollbar-thumb

BCD tables only load in the browser

css.selectors.-webkit-scrollbar-track

BCD tables only load in the browser

css.selectors.-webkit-scrollbar-track-piece

BCD tables only load in the browser

css.selectors.-webkit-scrollbar-corner

BCD tables only load in the browser

css.selectors.-webkit-resizer

BCD tables only load in the browser

Siehe auch