Warum Callbacks von Promise .then Methoden ein Anti-Pattern sind
Frage:
Ist es ein Anti-Pattern? Rückruffunktionen für AngularJS-Dienste innerhalb von Promise-.then-Methoden bereitstellen? Wenn ja, wie sollte der Code umgestaltet werden und warum?
Antwort:
Umgestalten des Codes:
Ändern Sie die getTokens-Methode im tokenService, um das Versprechen direkt zurückzugeben, anstatt einen Rückruf anzunehmen:
var getTokens = function() {
return $http.get('/api/tokens');
};
Verwenden Sie im Controller die .then-Methode, um Erfolgs-/Fehlerhandler zu verketten:
yourModule.getTokens()
.then(function(response) {
// handle it
});
Warum der ursprüngliche Weg ein Anti-Pattern war:
-
Verhindert eine weitere Verkettung von Promise-Handlern.Der ursprüngliche Code verhindert die Verkettung zusätzlicher .then-Methoden für weitere Verarbeitung der Antwort.
-
Konvertiert die Steuerung. Durch die Annahme eines Rückrufs wird die Steuerung der Verarbeitung der Antwort vom aufrufenden Modul auf das aufgerufene Modul verlagert, was nicht ideal ist.
-
Unnötige Verwendung von Versprechen.Während der $http-Dienst Versprechen zurückgibt, wandelt der ursprüngliche Code sie wieder in Rückrufe um, wodurch die Verwendung von Versprechen überflüssig wird.
-
Potenziell für Verwirrung. Die Verwendung von Versprechen als Rückrufe führt ein unnötiges Konzept in die Codebasis ein und kann für Teammitglieder schwer zu verstehen sein.
Das obige ist der detaillierte Inhalt vonWarum sind Callbacks in Promise .then-Methoden ein Anti-Pattern in AngularJS?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!
Stellungnahme: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