Maison > interface Web > tutoriel CSS > Comment puis-je désactiver de manière fiable les transitions CSS en JavaScript ?

Comment puis-je désactiver de manière fiable les transitions CSS en JavaScript ?

DDD
Libérer: 2024-11-30 09:22:10
original
257 Les gens l'ont consulté

How Can I Reliably Disable CSS Transitions in JavaScript?

Surmonter les défis des transitions CSS

Dans le domaine du développement Web, la désactivation temporaire des effets de transition CSS peut présenter un défi. Bien qu'il puisse sembler simple de simplement basculer entre une classe CSS, cette approche échoue souvent en raison de l'optimisation du navigateur.

La solution : une classe sans transition et une redistribution forcée

Pour désactiver efficacement les transitions, une classe CSS peut être utilisée pour définir toutes les propriétés de transition sur aucune en utilisant l'indicateur !important. Cependant, cette classeだけでは、期待した動作は得られません。

.notransition {
  -webkit-transition: none !important;
  -moz-transition: none !important;
  -o-transition: none !important;
  transition: none !important;
}
Copier après la connexion

L'astuce consiste à forcer une redistribution de l'élément après avoir modifié ses propriétés CSS. Cette actualisation supprime les modifications CSS en attente, garantissant ainsi que la transition est désactivée. Une méthode fiable consiste à accéder à la propriété offsetHeight de l'élément.

Implémentation JavaScript

Sans jQuery :

someElement.classList.add('notransition'); // Disable transitions
doWhateverCssChangesYouWant(someElement);
someElement.offsetHeight; // Trigger a reflow, flushing the CSS changes
someElement.classList.remove('notransition'); // Re-enable transitions
Copier après la connexion

Avec jQuery :

$someElement.addClass('notransition'); // Disable transitions
doWhateverCssChangesYouWant($someElement);
$someElement[0].offsetHeight; // Trigger a reflow, flushing the CSS changes
$someElement.removeClass('notransition'); // Re-enable transitions
Copier après la connexion

Mises en garde

Assurez-vous que !important est suffisant pour remplacer les styles existants. Sinon, envisagez d'utiliser element.style.setProperty pour désactiver et réactiver les transitions manuellement. Les préfixes des fournisseurs peuvent être omis, car la plupart des navigateurs modernes prennent en charge les transitions sans eux.

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