Heim >Web-Frontend >js-Tutorial >Beim Löschen von Timern in AngualrJs sind Probleme aufgetreten
In diesem Artikel werden hauptsächlich die Fallstricke vorgestellt, auf die der Clearing-Timer von AngualrJ stößt. Freunde in Not können sich darauf beziehen.
Der Weg, die Fallstricke des Clearing-Timers von AngualrJ zu überwinden:
Ich habe ein seltsames Problem gefunden Heute wird der in der benutzerdefinierten Anweisung platzierte Timer nach dem Seitensprung immer noch auf einer anderen Seite ausgeführt. Dies ist definitiv nicht möglich und beeinträchtigt die Leistung des Systems.
Ich habe die native Methode window.onunload in Angular verwendet, aber sie hat nicht funktioniert, also musste ich Angulars eigene Methode $destroy verwenden. Diese Seite springt und die DOM-Struktur ändert sich, der Timer kann gelöscht werden
var timer = setInterval(function(){ $scope.$apply(function(){ //这里是想要定时刷新的逻辑 }); },3000); $scope.$on('$destroy',function(){ if (timer) { clearInterval(timer); timer = null; } });
Lassen Sie mich hier darüber sprechen, da ich die nativen Funktionen setTimeout()
und setInterval()
in Javascript verwende, die entsprechenden sind also clearTimeout()
und clearInterval()
beim Löschen sind $timeOut
und $interval
, daher entspricht das Löschen $timeOut.cancel()
und $interval.cancel()
und
muss eins zu eins entsprechen. Inkonsistenzen werden nicht gelöscht.
Zusammenfassung
Das obige ist der detaillierte Inhalt vonBeim Löschen von Timern in AngualrJs sind Probleme aufgetreten. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!