Dynamisches Erstellen von „@-Keyframe“-CSS-Animationen
Um eine dynamische Anpassung von CSS-Animationen zu erreichen, können Sie Stylesheet-Regeln erstellen und einfügen fliegen. Mit diesem Ansatz können Sie vorhandene Stile überschreiben und die Animationsendpunkte basierend auf empfangenen Werten steuern.
Lösung:
Erstellen Sie einen Stil Element:
var style = document.createElement('style'); style.type = 'text/css';
Konstruieren Sie die Keyframes-Definition:
var keyFrames = '\ @-webkit-keyframes spinIt {\ 100% {\ -webkit-transform: rotate(A_DYNAMIC_VALUE);\ }\ }\ @-moz-keyframes spinIt {\ 100% {\ -webkit-transform: rotate(A_DYNAMIC_VALUE);\ }\ }';
Ersetzen den Platzhalter mit dem gewünschten Winkel:
style.innerHTML = keyFrames.replace(/A_DYNAMIC_VALUE/g, "180deg");
Fügen Sie den Stil in den Dokumentkopf ein:
document.getElementsByTagName('head')[0].appendChild(style);
Dadurch wird dynamisch eine CSS-Animation mit dem angegebenen Drehwinkel erstellt und angewendet. Sie können den Platzhalter A_DYNAMIC_VALUE nach Bedarf anpassen, um basierend auf vom Server bereitgestellten Werten zu rotieren.
Durch die Nutzung dieser Technik können Sie die Leistung optimieren, indem Sie native JS-Animationen vermeiden, die erhebliche CPU-Ressourcen verbrauchen können. Die dynamische Erstellung von Stylesheet-Regeln bietet die Flexibilität, Animationen im Handumdrehen anzupassen und so das Benutzererlebnis ohne zusätzliche externe Bibliotheken zu verbessern.
Das obige ist der detaillierte Inhalt vonWie erstelle ich dynamisch CSS-Animationen mit „@-Keyframes'?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!