Angular è fortemente basato sulle Reactive Extension. Un tipico esempio di questa affermazione lo si trova nell'esecuzione delle chiamate HTTP. Una chiamata HTTP, sia che la si effettui con la classe Http che con la classe HttpClient, restituisce un oggetto di tipo Observable<T>. Le Reactive Extension permettono di realizzare in poco tempo funzionalità che con le Promise sono realizzabili solo atteverso la scrittura di molto codice.
Un tipico esempio sono le retry in una chiamata HTTP. Esistono molti casi in cui una chiamata HTTP può andare in errore (mancanza temporanea di connessione, server momentaneamente non disponibile, e così via). In questi casi possiamo decidere di effettuare nuovamente la chiamata un certo numero di volte prima di sollevare realmente un'eccezione. Utilizzando le Reactive Extensions tutto questo può essere fatto utilizzando il metodo retry.
import 'rxjs/add/operator/retry';
...
http.get<Person>('/api/person/1')
.retry(3)
.subscribe(//code);In questo caso, la chiamata all'URL viene eseguita fino a un massimo di tre volte prima di andare in errore.
Questa stessa funzione è realizzabile anche utilizzando una Promise, ma dobbiamo scrivere a mano del codice che utilizzando le Reactive Extension abbiamo già a disposizione.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Usare la parola chiave field per semplificare la scrittura di proprietà in C#
Effettuare la ricerca di testo nascosto in una pagina web con Javascript
Implementare il throttle in JavaScript
Ricerca delle GitHub issue tramite operatori logici
Mischiare codice server side e client side in una query LINQ con Entity Framework
Disabilitare le run concorrenti di una pipeline di Azure DevOps
Definire il metodo di rilascio in .NET Aspire
Evidenziare una porzione di testo in un pagina dopo una navigazione
Ciclo di vita risorse con .NET Aspire
Configurare OpenTelemetry per Application Insights su ASP.NET Core
Utilizzo delle stepped value functions nel CSS
Ridimensionamento automatico input tramite CSS




