Heim > Web-Frontend > CSS-Tutorial > Wie kann ich CSS-Übergänge in JavaScript zuverlässig deaktivieren?

Wie kann ich CSS-Übergänge in JavaScript zuverlässig deaktivieren?

DDD
Freigeben: 2024-11-30 09:22:10
Original
264 Leute haben es durchsucht

How Can I Reliably Disable CSS Transitions in JavaScript?

Die Herausforderungen von CSS-Übergängen meistern

Im Bereich der Webentwicklung kann das vorübergehende Deaktivieren von CSS-Übergangseffekten eine Herausforderung darstellen. Obwohl es einfach erscheinen mag, einfach eine CSS-Klasse umzuschalten, greift dieser Ansatz aufgrund der Browseroptimierung oft zu kurz.

Die Lösung: Eine Klasse ohne Übergang und erzwungener Reflow

Um Übergänge effektiv zu deaktivieren, Eine CSS-Klasse kann verwendet werden, um mithilfe des Flags !important alle Übergangseigenschaften auf „Keine“ zu setzen. Allerdings besteht diese Klasse darin, einen Reflow des Elements zu erzwingen, nachdem seine CSS-Eigenschaften geändert wurden. Durch diese Aktualisierung werden die ausstehenden CSS-Änderungen gelöscht und sichergestellt, dass der Übergang deaktiviert ist. Eine zuverlässige Methode ist der Zugriff auf die offsetHeight-Eigenschaft des Elements.

.notransition {
  -webkit-transition: none !important;
  -moz-transition: none !important;
  -o-transition: none !important;
  transition: none !important;
}
Nach dem Login kopieren
JavaScript-Implementierung

Ohne jQuery:

Mit 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
Nach dem Login kopieren

Vorbehalte

$someElement.addClass('notransition'); // Disable transitions
doWhateverCssChangesYouWant($someElement);
$someElement[0].offsetHeight; // Trigger a reflow, flushing the CSS changes
$someElement.removeClass('notransition'); // Re-enable transitions
Nach dem Login kopieren
Stellen Sie sicher, dass !important ausreicht, um vorhandene Stile zu überschreiben. Wenn nicht, sollten Sie die Verwendung von element.style.setProperty in Betracht ziehen, um Übergänge manuell zu deaktivieren und wieder zu aktivieren. Herstellerpräfixe können weggelassen werden, da die meisten modernen Browser Übergänge ohne diese unterstützen.

Das obige ist der detaillierte Inhalt vonWie kann ich CSS-Übergänge in JavaScript zuverlässig deaktivieren?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage