Dieser Inhalt wurde automatisch aus dem Englischen übersetzt, und kann Fehler enthalten. Erfahre mehr über dieses Experiment.

View in English Always switch to English

scroll-timeline CSS-Eigenschaft

Eingeschränkt verfügbar

Diese Funktion ist nicht Baseline, da sie in einigen der am weitesten verbreiteten Browser nicht funktioniert.

Die scroll-timeline CSS Kurzschreibweise wird verwendet, um eine benannte Scroll-Fortschritts-Timeline zu definieren, die durch das Scrollen eines scrollbaren Elements (scroller) zwischen oben und unten (oder links und rechts) fortschreitet.

Zusammengesetzte Eigenschaften

Diese Eigenschaft ist eine Kurzschreibweise für die folgenden CSS-Eigenschaften, in dieser Reihenfolge:

Syntax

css
/* One value */
scroll-timeline: none;
scroll-timeline: --custom_name_for_timeline;

/* Two values */
scroll-timeline: --custom_name_for_timeline block;
scroll-timeline: --custom_name_for_timeline x;
scroll-timeline: none inline;
scroll-timeline: none y;

/* Global values */
scroll-timeline: inherit;
scroll-timeline: initial;
scroll-timeline: revert;
scroll-timeline: revert-layer;
scroll-timeline: unset;

Werte

<scroll-timeline-name>

Ein <dashed-ident> oder das Schlüsselwort none.

<scroll-timeline-axis>

Ein <axis>-Schlüsselwort. Der Standardwert ist block.

Beschreibung

Die scroll-timeline-Kurzschreibweise kann auf ein Container-Element angewendet werden, um sowohl die scroll-timeline-name- als auch die scroll-timeline-axis-Eigenschaft festzulegen. Sie wird auf dem Scroller gesetzt, der die Timeline bereitstellen wird. Wenn der Container kein Überlauf hat, der gescrollt werden kann, oder wenn der Überlauf verborgen oder abgeschnitten ist, wird keine Timeline erstellt.

Der Wert für die scroll-timeline-name, wenn er nicht auf none gesetzt ist, muss ein <dashed-ident> sein, was bedeutet, dass er mit -- beginnen muss. Dies hilft, Namenskonflikte mit standardmäßigen CSS-Schlüsselwörtern zu vermeiden. Der Name kann dann als Wert der animation-timeline-Eigenschaft eines Elements verwendet werden, um das scrollende Container-Element zu definieren, das seine Animationstimeline definiert, welche den Animationsfortschritt beim Scrollen antreibt.

Der optionale Scroll <axis>-Wert definiert die scroll-timeline-axis, die standardmäßig block ist, wenn weggelassen. Wenn sowohl ein Name als auch eine Achse angegeben sind, muss die Reihenfolge der <scroll-timeline-name>-Wert gefolgt vom <axis>-Wert sein. Wenn die <axis> zuerst aufgeführt wird, ist die Deklaration ungültig und wird ignoriert.

Formale Definition

Anfangswertwie die jeweiligen Kurzschreibweisen:
Anwendbar aufScrollcontainer
VererbtNein
Berechneter Wertwie die jeweiligen Kurzschreibweisen:
Animationstypwie die jeweiligen Kurzschreibweisen:

Formale Syntax

scroll-timeline = 
[ <'scroll-timeline-name'> <'scroll-timeline-axis'>? ]#

<scroll-timeline-name> =
[ none | <dashed-ident> ]#

<scroll-timeline-axis> =
[ block | inline | x | y ]#

Beispiele

Erstellen einer benannten Scroll-Fortschritts-Timeline-Animation

In diesem Beispiel wird eine Scroll-Timeline namens --square-timeline mit der Eigenschaft scroll-timeline-name auf dem #container-Element definiert. Der Timeline-Name wird dann mit animation-timeline: --square-timeline auf die Animation auf dem #square-Element angewendet.

HTML

Wir fügen einen Container mit zwei <div>-Kind-Elementen ein.

html
<div id="container">
  <div id="square"></div>
  <div id="stretcher"></div>
</div>

CSS

Wir setzen den Container auf 300px Höhe, um ihn vertikal scrollen zu lassen.

Mit der Eigenschaft scroll-timeline definieren wir den Container als Quelle einer Scroll-Timeline namens --square-timeline und setzen explizit die standardmäßige vertikale Bildlaufleiste als Timeline-Controller.

css
#container {
  height: 300px;
  overflow-y: scroll;

  scroll-timeline: --square-timeline y;
  /* Firefox supports the non-standard vertical/horizontal syntax */
  scroll-timeline: --square-timeline vertical;

  position: relative;
}

Wir bieten grundlegende Stile für das Quadrat an. Wir wenden die rotateAnimation mit der animation-name-Eigenschaft an. Standardmäßig würde dies die zeitbasierte Dokument-Timeline verwenden. Durch das Setzen der animation-timeline-Eigenschaft auf die oben genannte --square-timeline-Timeline legen wir fest, dass das Quadrat gemäß der scrollbasierten Timeline rotiert, die fortschreitet, während der Container scrollt.

css
#square {
  background-color: deeppink;
  width: 100px;
  height: 100px;
  position: absolute;
  bottom: 0;

  animation: rotateAnimation 1ms linear;
  animation-timeline: --square-timeline;
}

Wir stellen sicher, dass der Container überläuft, indem wir einen Strecker definieren, der breiter als sein Elternteil ist. Ohne Inhalt, der den Container überflutet, würde es keine Bildlaufleiste und daher keine Scroll-Timeline geben. Wir definieren auch eine CSS-Keyframe-Animation, die die Elemente, auf die sie angewendet wird, um eine volle Drehung dreht.

css
#stretcher {
  height: 600px;
  background: #dedede;
}

@keyframes rotateAnimation {
  from {
    transform: rotate(0deg);
  }

  to {
    transform: rotate(360deg);
  }
}

Ergebnis

Scrollen Sie die vertikale Leiste, um zu sehen, wie das Quadrat animiert wird, während Sie scrollen.

Das Quadrat animiert sich, während Sie scrollen. Bei der Verwendung von scroll-timeline hängt die Dauer der Animation davon ab, wie schnell Sie scrollen, nicht vom Wert der animation-duration-Eigenschaft.

Spezifikationen

Spezifikation
Scroll-driven Animations
# scroll-timeline-shorthand

Browser-Kompatibilität

Siehe auch