scroll-initial-target CSS property
Eingeschränkt verfügbar
Diese Funktion ist nicht Baseline, da sie in einigen der am weitesten verbreiteten Browser nicht funktioniert.
Experimentell: Dies ist eine experimentelle Technologie
Überprüfen Sie die Browser-Kompatibilitätstabelle sorgfältig vor der Verwendung auf produktiven Webseiten.
Die scroll-initial-target-Eigenschaft von CSS ermöglicht die Definition von Elementen, die potenzielle Snap-Ziele sind, wenn ihr Vorfahre ein scroll container ist und zum ersten Mal gerendert wird.
Syntax
/* Keyword values */
scroll-initial-target: none;
scroll-initial-target: nearest;
/* Global values */
scroll-initial-target: inherit;
scroll-initial-target: initial;
scroll-initial-target: revert;
scroll-initial-target: revert-layer;
scroll-initial-target: unset;
Werte
Beschreibung
Die scroll-initial-target-Eigenschaft ermöglicht es, Elemente zu definieren, die bei der ersten Darstellung ihrer übergeordneten scroll snap-Container eingerastet werden sollen. Wenn der Wert nearest gesetzt wird, wird das Element als potenzielles Ziel definiert, zu dem beim ersten Erscheinen des nächsten Vorfahren scroll container auf der Seite eingerastet werden soll.
Wenn mehrere Elemente oder Pseudo-Elemente im scroll container auf nearest gesetzt sind, ist das erste Element in der Baumreihenfolge das anfängliche Ziel für das Einrasten beim Scrollen.
Der Anfangswert ist none, was bedeutet, dass ein Scroll-Snap-fähiges Element standardmäßig kein anfängliches Scroll-Ziel ist. Der Wert none kann auch auf einem Element gesetzt werden, um explizit sicherzustellen, dass es kein anfängliches Scroll-Ziel ist.
Wenn die anfängliche Scroll-Position eines scroll container sowohl durch die place-content-Eigenschaft für die Inhaltsverteilung als auch durch scroll-initial-target auf einem der Nachkommen potenziell festgelegt wird, gewinnt der erste Nachkomme mit scroll-initial-target: nearest.
Formale Definition
| Anfangswert | none |
|---|---|
| Anwendbar auf | alle Elemente |
| Vererbt | Nein |
| Berechneter Wert | the specified keyword |
| Animationstyp | Not animatable |
Formale Syntax
scroll-initial-target =
none |
nearest
Beispiele
>Verwendung von scroll-initial-target
Das folgende Beispiel zeigt die beiden Werte von scroll-initial-target und wie das erste Element mit scroll-initial-target eingerastet wird.
HTML
Wir fügen 5 Container hinzu, die von einem Absatz eingeleitet werden, der die erwartete Wirkung erklärt.
<p><code>none</code> on #4 only</p>
<div class="none">
<div>1</div>
<div>2</div>
<div>3</div>
<div class="set">4</div>
<div>5</div>
</div>
<p><code>nearest</code> on #4 only</p>
<div class="nearest">
<div>1</div>
<div>2</div>
<div>3</div>
<div class="set">4</div>
<div>5</div>
</div>
<p><code>nearest</code> on even elements</p>
<div class="nearest">
<div>1</div>
<div class="set">2</div>
<div>3</div>
<div class="set">4</div>
<div>5</div>
</div>
<p><code>nearest</code> on odd elements</p>
<div class="nearest">
<div class="set">1</div>
<div>2</div>
<div class="set">3</div>
<div>4</div>
<div class="set">5</div>
</div>
<p><code>nearest</code> on odd elements, with <code>none</code> on #1</p>
<div class="nearest">
<div class="set unset">1</div>
<div>2</div>
<div class="set">3</div>
<div>4</div>
<div class="set">5</div>
</div>
CSS
Wir richten die Elemente mit den nächstgelegenen und keinen Attributen als scroll-snap-Container ein und zentrieren die eingeklappten Elemente.
/* mandatory scroll-snap on parent */
div.nearest,
div.none {
scroll-snap-type: x mandatory;
}
/* scroll-snap alignment for children */
div > div {
scroll-snap-align: center;
scroll-initial-target: always;
}
Anschließend setzen wir scroll-initial-target entweder auf none oder nearest bei allen Elementen mit der .set-Klasse.
.none .set,
.nearest .set.unset {
scroll-initial-target: none;
}
.nearest .set {
scroll-initial-target: nearest;
}
Ergebnis
Die Wirkung der Eigenschaft wird gezeigt, wenn der scroll-snap-Container auf die Seite gezeichnet wird.
Jede Reihe rastet zum ersten Element mit nearest ein, falls vorhanden, in Baumreihenfolge. Im letzten Beispiel haben wir den Wert nearest beim ersten Element mit none überschrieben, sodass das erste Element mit angewendetem nearest #3 ist.
Spezifikationen
| Spezifikation |
|---|
| CSS Scroll Snap Module Level 2> # propdef-scroll-initial-target> |