Le Promise sono gli oggetti che permettono al JavaScript di gestire la programmazione asincrona. Molto spesso nel nostro codice usiamo solamente il metodo 'get', che come possiamo immaginare permette di ottenere il risultato dell'operazione asincrona, ma esistono anche altri metodi e utility che ci permetteranno di gestire tutte le varianti.
Partiamo dalla definizione di una promise risolta (resolve) e una fallita (reject).
const promise1 = new Promise((resolve, reject) => { resolve('Success!'); }); const promise1 = new Promise((resolve, reject) => { reject('Exception') // o anche // throw 'Exception'; });
Dobbiamo ora leggere questi valori utilizzando i metodi then e catch.
Promise.resolve('OK').then((value) => { console.log(value); // "OK" }) /// Promise.reject('NO').then((value) => { console.log(value); }).catch((error) => { console.log(error); // "NO" });
Infine, se volessimo eseguire operazioni sia in caso di successo che di rigetto, utilizzeremo finally.
Promise.resolve('OK').then((value) => { console.log(value); // "OK" }) /// Promise.reject('NO').then((value) => { console.log(value); }).catch((error) => { console.log(error); }).finally(()=>{ console.log("promise completata") });
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Eseguire una ricerca avanzata per recuperare le issue di GitHub
Gestire gli accessi con Token su Azure Container Registry
Creare una libreria CSS universale: Nav menu
Aggiornare a .NET 9 su Azure App Service
Inference di dati strutturati da testo con Semantic Kernel e ASP.NET Core Web API
Gestire il colore CSS con HWB
Gestione CSS in Blazor con .NET 9
Filtering sulle colonne in una QuickGrid di Blazor
Utilizzare il metodo IntersectBy per eseguire l'intersection di due liste
Usare il colore CSS per migliorare lo stile della pagina
Managed deployment strategy in Azure DevOps
Utilizzare EF.Constant per evitare la parametrizzazione di query SQL