Nell'articolo sull'uso di PRISM per realizzare Windows Store app (https://www.winrtitalia.com/articoli/windows8/XAML-Windows-8.1-WinRT-PRISM.aspx) abbiamo introdotto l'utilizzo di Unity come dependency injection container per l'istanza dei ViewModel e altri oggetti.
L'utilizzo di Unity, tuttavia, non e' obbligatorio: la risoluzione dei VieModel viene invocata dal ViewModelLocator attraverso il metodo Resolve esposto da MvvmAppBase.
Il metodo Resolve accetta come parametro il Type di una classe (nel nostro contesto, appunto, un ViewModel), è virtual e la sua implementazione crea l'istanza della classe attraverso reflection:
protected virtual object Resolve(Type type) { return Activator.CreateInstance(type); }
Un aspetto interessante è la possibilita' di definire una strategia di recupero del Type di un ViewModel in relazione ad una View: il ViewTypeToViewModelTypeResolver predefinito nel ViewModelLocator è proprio quello in cui è fissata la convenzione delle folder Views,ViewModels e del suffisso ViewModel al nome di una View.
private static Func<Type, Type> defaultViewTypeToViewModelTypeResolver = viewType => { var viewName = viewType.FullName; viewName = viewName.Replace(".Views.", ".ViewModels."); var viewAssemblyName = viewType.GetTypeInfo().Assembly.FullName; var viewModelName = String.Format(CultureInfo.InvariantCulture, "{0}ViewModel, {1}", viewName, viewAssemblyName); return Type.GetType(viewModelName); };
Con il metodo SetDefaultViewTypeToViewModelTypeResolver di ViewModelLocator possiamo definire il ViewTypeToViewModelTypeResolver ed impostare le proprie convenzioni di associazione tra View e ViewModel.
Oltre a questo, qualora avessimo bisogno di istanziare manualmente i ViewModel, anche con oggetti passati come parametri nel costruttore, possiamo usare il metodo Register del ViewModelLocator e definire il delegate per restituire il ViewModel.
ViewModelLocator.Register(typeof(MainPage).ToString(), () => new MainPageViewModel(_dataRepository, NavigationService));
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Configurare e gestire sidecar container in Azure App Service
Scrivere selettori CSS più semplici ed efficienti con :is()
Combinare Container Queries e Media Queries
Utilizzare EF.Constant per evitare la parametrizzazione di query SQL
Utilizzare WhenEach per processare i risultati di una lista di task
Rinnovare il token di una GitHub App durante l'esecuzione di un workflow
Aprire una finestra di dialogo per selezionare una directory in WPF e .NET 8
Gestire gli accessi con Token su Azure Container Registry
Utilizzare il trigger SQL con le Azure Function
Gestione degli stili CSS con le regole @layer
Supporto ai tipi DateOnly e TimeOnly in Entity Framework Core
Utilizzare una qualunque lista per i parametri di tipo params in C#