La comunicazione tra View e ViewModel è sempre un argomento delicato da trattare. Rendere minimo l'accoppiamento non è facile. In caliburn micro possiamo utilizzare le coroutine, per comunicare con la View e cambiare tra uno stato visuale e l'altro.
Una coorutine è una classe che implementa l'interfaccia IResult
public interface IResult { event EventHandler<ResultCompletionEventArgs> Completed; void Execute(CoroutineExecutionContext context); }
L'interfaccia definisce un evento ed un metodo. È possibile trovare un implementazione base di questa interfaccia nella classe ResultBase. Quest'ultima è scaricabile assieme al codice sorgente di Caliburn.
Useremo questa classe per creare la nostra coroutine che cambia lo stato visuale di una View
public class VisualStateResult : ResultBase { private readonly string _stateName; private readonly bool _useTransitions; public VisualStateResult(string stateName, bool useTransitions = true) { _stateName = stateName; _useTransitions = useTransitions; } public string StateName { get { return _stateName; } } public bool UseTransitions { get { return _useTransitions; } } public override void Execute(CoroutineExecutionContext context) { if (!(context.View is Control)) throw new InvalidOperationException("la View deve essere un controllo"); var view = (Control)context.View; VisualStateManager.GoToState(view, StateName, UseTransitions); OnCompleted(); } }
Il cuore dell'implementazione è l'override del metodo Execute, che recuperata la View e utilizzando il VisualStateManager cambia lo stato visuale.
Infine è possibile utilizzare la classe appena creata avendo l'accartezza di farlo in un metodo che restituisce un IEnumerable.
public IEnumerable<IResult> Execute() { yield return new VisualStateResult("Loading"); }
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Usare Refit e Polly in Blazor per creare client affidabili e fortemente tipizzati
Configurare dependabot per aggiornare le dipendenze di terze parti con GitHub Actions
Registrare servizi multipli tramite chiavi in ASP.NET Core 8
Routing statico e PreRendering in una Blazor Web App
Utilizzare gli snapshot con Azure File shares
Definire lo stile CSS in base alle dimensioni del container
Gestire undefined e partial nelle reactive forms di Angular
Le novità di Angular: i miglioramenti alla CLI
Eseguire un metodo asincrono dopo il set di una proprietà in Blazor 8
Usare un KeyedService di default in ASP.NET Core 8
Utilizzare la session affinity con Azure Container Apps
Aggiungere interattività lato server in Blazor 8