Heim >Web-Frontend >CSS-Tutorial >Wie kann ich CSS-Animationsparameter dynamisch anpassen?

Wie kann ich CSS-Animationsparameter dynamisch anpassen?

Patricia Arquette
Patricia ArquetteOriginal
2024-11-29 07:29:14847Durchsuche

How Can I Dynamically Customize CSS Animation Parameters?

Anpassen von CSS-Animationen mit parametrisierten Werten

Die bereitgestellte CSS-Animation legt die Dauer und Parameter für ein von links hineingleitendes Element fest. Was aber, wenn Sie diese Parameter je nach Kontext dynamisch anpassen möchten?

Eine Möglichkeit, dies zu erreichen, ist die Verwendung von CSS-Variablen. So geht's:

p {
animation-duration: 3s;
animation-name: slidein;
}

@keyframes slidein {
from {

margin-left: var(--m, 0%);
width: var(--w, 100%);

}

zu {

margin-left: 0%;
width: 100%;

}
}

Jetzt können Sie mithilfe von JavaScript die Werte für --m (Rand links) und --w (Breite) wie folgt festlegen:

document.querySelector('.p2').style.setProperty('--m', '100%');
document.querySelector('.p2').style.setProperty('--w', '300%');

Damit können Sie die Animationsparameter für steuern bestimmte Elemente dynamisch.

Betrachten Sie als Beispiel zwei Absätze mit den Klassennamen „p1“ und "p2":

.p1,.p2 {
animation-duration: 3s;
animation-name: slidein;
}

Dies wird nicht animieren, da die Animation den für die Variable festgelegten Standardwert verwendet


Dies wird animiert, weil wir die CSS-Variable mit JS geändert haben

Der erste Absatz wird nicht animiert, weil er die Standardwerte für --m und --w verwendet. Der zweite Absatz wird jedoch gemäß den in JavaScript festgelegten benutzerdefinierten Parametern animiert.

Das obige ist der detaillierte Inhalt vonWie kann ich CSS-Animationsparameter dynamisch anpassen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn