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
Implementare il throttle in JavaScript
Change tracking e composition in Entity Framework
Persistere la ChatHistory di Semantic Kernel in ASP.NET Core Web API per GPT
Gestire progetti NPM in .NET Aspire
Applicare un filtro per recuperare alcune issue di GitHub
Utilizzare i variable font nel CSS
Documentare i servizi REST con Swagger e OpenAPI con .NET 9
Managed deployment strategy in Azure DevOps
Gestione file Javascript in Blazor con .NET 9
Effettuare il log delle chiamate a function di GPT in ASP.NET Web API
Utilizzare il metodo CountBy di LINQ per semplificare raggruppamenti e i conteggi
Evitare memory leaks nelle closure JavaScript
I più letti di oggi
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!
- Documentare i servizi REST con Swagger e OpenAPI con .NET 9
- Impersonation di utente per l'esecuzione di codice in una pagina ASP.NET
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!