Capita spesso di realizzare applicativi dei servizi in Blazor che richiedono un'inizializzazione asincrona - per esempio per recuperare dei parametri di configurazione tramite una chiamata HTTP.
Purtroppo, come sappiamo, non possiamo invocare metodi asincroni in un costruttore, quindi tipicamente la soluzione consiste nello scrivere codice boilerplate come il seguente, ossia creando un metodo che si occupi di inizializzare MyService, e che dobbiamo ricordarci di invocare in ognuno degli altri metodi che MyService espone.
public class MyService { private bool _isInitialized; public async Task Method1() { await this.EnsureInitializedAsync(); // Codice di Method1 } public async Task Method2() { await this.EnsureInitializedAsync(); // Codice di Method2 } public async Task EnsureInitializedAsync() { if (!_isInitialized) { // Codice di inizializzazione } } }
Ovviamente, oltre che scomoda, questa tecnica è anche soggetta a errori, perché potremmo dimenticarci la chiamata a EnsureInitializedAsync e introdurre bug nell'applicazione.
Una possibile alternativa, allora, è forzare l'inizializzazione di questa classe allo Startup, tramite il seguente codice:
public class Program { public static async Task Main(string[] args) { var builder = WebAssemblyHostBuilder.CreateDefault(args); builder.RootComponents.Add<App>("#app"); // registro i servizi su IoC container... builder.Services.AddScoped<MyService>(); var host = builder.Build(); var myService = host.Services.GetRequiredService<MyService>(); await myService.InitializeAsync(); await host.RunAsync(); } }
Dopo aver registrato il servizio, abbiamo rimpiazzato la tipica linea di codice
await builder.Build().RunAsync();
con una versione che dopo aver creato l'host, richieda un'istanza di MyService prima di chiamare RunAsync.
Essendo Main un metodo asincrono, possiamo effettuare l'await della nostra chiamata di inizializzazione. Inoltre, dato che questo codice viene eseguito prima che il componente App venga istanziato, siamo certi che nessun altro componente invochi MyService prima che questo sia pienamente operativo.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Eseguire i worklow di GitHub su runner potenziati
Esporre i propri servizi applicativi con Semantic Kernel e ASP.NET Web API
Ottimizzazione dei block template in Angular 17
Generare token per autenicarsi sulle API di GitHub
Visualizzare le change sul plan di Terraform tramite le GitHub Actions
Creazione di plugin per Tailwind CSS: espandere le funzionalità del framework dinamicamente
Evitare (o ridurre) il repo-jacking sulle GitHub Actions
Paginare i risultati con QuickGrid in Blazor
Utilizzare Tailwind CSS all'interno di React: installazione
Effettuare il refresh dei dati di una QuickGrid di Blazor
C# 12: Cosa c'è di nuovo e interessante
Modificare i metadati nell'head dell'HTML di una Blazor Web App
I più letti di oggi
- Effettuare il log delle chiamate a function di GPT in ASP.NET Web API
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!
- Utilizzare il metodo CountBy di LINQ per semplificare raggruppamenti e i conteggi
- Creare una libreria CSS universale: Cards
- Eseguire script pre e post esecuzione di un workflow di GitHub