CSS-Eigenschaft scroll-timeline
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-Fortschritt-Zeitleiste 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 Kurzform für die folgenden CSS-Eigenschaften in dieser Reihenfolge:
Syntax
/* 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üsselwortnone. <scroll-timeline-axis>-
Ein
<axis>Schlüsselwort. Der Standardwert istblock.
Beschreibung
Die scroll-timeline Kurzschreibweise kann auf ein Containerelement angewendet werden, um sowohl die scroll-timeline-name als auch die scroll-timeline-axis Eigenschaften festzulegen. Sie wird auf den Scroller gesetzt, der die Zeitleiste bereitstellt. Wenn das Container-Element keinen Überlauf zum Scrollen hat oder wenn der Überlauf versteckt oder abgeschnitten ist, wird keine Zeitleiste erstellt.
Der Wert für die scroll-timeline-name, falls nicht auf none gesetzt, 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 Containerelement zu definieren, das seine Animationszeitleiste definiert und den Animationsfortschritt beim Scrollen steuert.
Das optionale Scroll-<axis>-Wert definiert die scroll-timeline-axis, die standardmäßig block ist, wenn sie weggelassen wird. 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 ist, ist die Deklaration ungültig und wird ignoriert.
Formale Definition
| Anfangswert | wie die jeweiligen Kurzschreibweisen:
|
|---|---|
| Anwendbar auf | Scrollcontainer |
| Vererbt | Nein |
| Berechneter Wert | wie die jeweiligen Kurzschreibweisen:
|
| Animationstyp | wie 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-Fortschritt-Zeitleistenanimation
In diesem Beispiel wird eine Scroll-Zeitleiste namens --square-timeline definiert, indem die Eigenschaft scroll-timeline-name auf das #container Element angewendet wird. Der Zeitleistenname wird dann auf die Animation des #square Elementes mit animation-timeline: --square-timeline angewendet.
HTML
Wir fügen einen Container mit zwei <div>-Kind-Elementen ein.
<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.
Durch die Verwendung der scroll-timeline Eigenschaft definieren wir den Container als Quelle einer Scroll-Zeitleiste namens --square-timeline und setzen explizit die Standard-vertikale Scrollleiste als den Zeitstrahl-Controller.
#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 stellen grundlegende Styles für das Quadrat bereit. Wir wenden die rotateAnimation mit der animation-name Eigenschaft an. Standardmäßig würde dies die zeitbasierte Dokumentenzeitleiste verwenden. Durch das Setzen der animation-timeline Eigenschaft auf die oben benannte --square-timeline Zeitleiste, wird das Quadrat so eingestellt, dass es sich entsprechend der scroll-basierten Zeitleiste dreht, die fortschreitet, während der Container scrollt.
#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 Dehner definieren, der breiter als sein Elterncontainer ist. Ohne Inhalt, der den Container überläuft, gäbe es keine Scrollleiste und daher keine Scroll-Zeitleiste. Wir definieren auch eine CSS-Schlüsselbildanimation, die die Elemente, auf die sie angewendet wird, um eine volle Umdrehung dreht.
#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 sich das Quadrat beim Scrollen animiert.
Das Quadrat animiert sich beim 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> |