Maison > interface Web > tutoriel CSS > Comment puis-je transmettre des variables JavaScript aux animations CSS ?

Comment puis-je transmettre des variables JavaScript aux animations CSS ?

DDD
Libérer: 2024-12-08 01:06:12
original
599 Les gens l'ont consulté

How Can I Pass JavaScript Variables to CSS Animations?

Passer des variables aux animations CSS avec JavaScript

Lorsque vous travaillez avec des animations CSS, la possibilité de transmettre des valeurs en tant que paramètres à partir de JavaScript peut être incroyablement utile. Cela permet une expérience dynamique et interactive.

Solution : Variables CSS

En CSS, l'utilisation de variables permet de transmettre des valeurs de JavaScript aux animations. Par exemple :

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

@keyframes slidein {
  from {
    margin-left: var(--m, 0%);
    width: var(--w, 100%);
  }
  to {
    margin-left: 0%;
    width: 100%;
  }
}
Copier après la connexion

Implémentation en JavaScript

À l'aide de JavaScript, vous pouvez ensuite définir ces variables :

document.querySelector('.p2').style.setProperty('--m','100%');
document.querySelector('.p2').style.setProperty('--w','300%');
Copier après la connexion

Exemple d'utilisation

Cela permettra modifier l'animation de l'élément avec la classe "p2":

<p class="p1">
 This will not animate as the animation will use the default value set to the variable
</p>
<p class="p2">
  This will animate because we changed the CSS variable using JS
</p>
Copier après la connexion

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal