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
Esecuzione condizionale delle pipeline in Azure DevOps
Condividere una variabile tra stage in una pipeline YAML di Azure DevOps
Uso dei design-time data nelle applicazioni della Universal Windows Platform
Utilizzare Live metrics con le Azure Functions
Usare i Top Level statement in C#
Paginare un elenco con Blazor Server
Utilizzare la modalità serverless con Azure Cosmos DB
Eseguire più query che tornano un singolo dato in un solo comando con la libreria Entity Framework Plus
Sviluppare codice nativo per Windows e Linux con .NET Core
Introduzione a Blazor WebAssembly
Produttività con C# 9
Utilizzare il CSS Grid Model per creare il layout di un sito