Nello script precedente abbiamo iniziato un'analisi della programmazione asincrona in JavaScript utilizzando le Promise. Ora vedremo alcuni metodi utili per gestire più promise nello stesso momento.
Promise.all
Unisce tutte le Promise in una sola contenente un array di risultati delle singole.
const p1 = Promise.resolve("Ciao"); const p2 = new Promise((resolve, reject) => { setTimeout(resolve, 200, 'Mondo'); }); Promise.all([p1, p2]).then((values) => { console.log(values); // ["Ciao", "Mondo"] });
Promise.race
Fornendo un'array di Promise, restituisce una Promise che si risolverà solo con il valore della più veloce.
const p1 = new Promise((resolve, reject) => { setTimeout(resolve, 200, 'Ciao'); }); const p2 = new Promise((resolve, reject) => { setTimeout(resolve, 2000, 'Mondo'); }); Promise.race([p1, p2]).then((value) => { console.log(value); // "Ciao" });
Promise.any
A seguito della fornitura di un array di Promise, restituisce la prima riuscita. Nel caso tutte falliscano anche la promise risultante fallirà.
const p0 = Promise.reject(0); const p1 = new Promise((resolve, reject) => { setTimeout(resolve, 200, 'Ciao'); }); const p2 = new Promise((resolve, reject) => { setTimeout(resolve, 2000, 'Mondo'); }); Promise.race([p0, p1, p2]).then((value) => { console.log(value); // "Ciao" });
Promise.allSettled
Questo metodo è molto simile al metodo all, ma permette l'esecuzione di tutte le Promise, indipendentemente dal fallimento di una o più.
const p0 = Promise.reject("Fallimento"); const p1 = Promise.resolve("Ciao"); const p2 = new Promise((resolve, reject) => { setTimeout(resolve, 200, 'Mondo'); }); Promise.allSettles([p0, p1, p2]).then((values) => { values.forEach((value) => console.log(value) // Object { status: "rejected", reason: "Fallimento" } // Object { status: "fulfilled", value: "Ciao" } // Object { status: "fulfilled", value: "Mondo" } });
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Specificare il numero di parentesi graffe nella string interpolation in combinazione con i string literal in C#
Impostare un default custom per i metodi LINQ che tornano il valore di default
Consumare un endpoint generico in Blazor
Collegare servizi a Azure Container App con i service connector
Definire le impostazioni di cache a livello di controller in ASP.NET Core 7
Definire lo stile CSS in base alle dimensioni del container
Sviluppo applicazioni x-plat con .NET MAUI
Usare ASP.NET Core dev tunnels per testare le applicazioni su internet
Recuperare la data di creazione e ultima modifica di un record con Entity Framework Core e le temporal table di SQL Server
Utilizzo di Map e Object in Javascript
Taggare la output cache in base al routing in ASP.NET Core
Utilizzare i nuovi piani dedicati di Azure Container Apps