Heim > Web-Frontend > CSS-Tutorial > Warum funktioniert meine JavaScript-Animationsfunktion im IE, schlägt jedoch in Chrome fehl?

Warum funktioniert meine JavaScript-Animationsfunktion im IE, schlägt jedoch in Chrome fehl?

Barbara Streisand
Freigeben: 2024-12-06 07:04:11
Original
550 Leute haben es durchsucht

Why Does My JavaScript `animate` Function Work in IE but Fail in Chrome?

JavaScript-Funktion „Animieren“ schlägt in Chrome trotz Arbeit im IE fehl

Problem:

Eine Animationsfunktion, aufgerufen über Ein Event-Handler-Inhaltsattribut kann in Chrome nicht ausgeführt werden, während es im Internet normal funktioniert Explorer.

Erklärung:

In Chrome wird die globale Animationsfunktion durch das kürzlich in Webanimationen eingeführte Element.prototype.animate überschattet. Diese Schattenbildung entsteht aufgrund des lexikalischen Umgebungsbereichs von Ereignishandlern, der den Bereich des Zielelements gegenüber dem globalen Bereich priorisiert.

Lösung:

Um das Problem zu beheben , können Sie entweder:

  • Die Animationsfunktion umbenennen: Einen anderen Namen verwenden, B. animate__, um Verwechslungen mit der Funktion Element.prototype.animate zu vermeiden.
function animate__() {
  var div = document.getElementById('demo');
  div.style.left = "200px";
  div.style.color = "red";
}
Nach dem Login kopieren
  • Verwenden Sie die Methode bind(): Binden Sie die Funktion animate an die globales Objekt, um sicherzustellen, dass es immer im globalen Bereich ausgeführt wird.
document.getElementById('demo').addEventListener('click', function() {
  animate().bind(window);
});
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonWarum funktioniert meine JavaScript-Animationsfunktion im IE, schlägt jedoch in Chrome fehl?. 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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage