Model、View、ViewModel结构以及全局视图模型注入器的说明

本文介绍了MVVMLight在WPF项目中的应用,详细阐述了MVVM架构的组成部分:View负责展示,ViewModel处理业务逻辑,Model处理数据实体。重点讲解了ViewModelLocator的作用,作为全局视图模型注入器,它在App初始化时注册并提供单一实例的ViewModel,实现了View和ViewModel的解耦。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

上一篇我们已经介绍了如何使用NuGet把MVVMLight应用到我们的WPF项目中。这篇我们来了解下一个基本的MVVMLight框架所必须的结构和运行模式。
MVVMLight安装之后,我们可以看到简易的框架布局,如上篇,生成了一个ViewModel文件夹,ViewModel层的内容都放在这边,除了Main对象的ViewModel之外,还包含一个ViewModelLocator文 件,用来注入当前的ViewModel全局实例。
在这里插入图片描述

如图:
1、View负责前端展示,与ViewModel进行数据和命令的交互。
2、ViewModel,负责前端视图业务级别的逻辑结构组织,并将其反馈给前端。
3、Model,主要负责数据实体的结构处理,与ViewModel进行交互。
根据上述的分层,我们来进行编码。先建立一个完整三层结构的目录,如图,包含Model、View、ViewModel三层文件夹:
在这里插入图片描述

当然除了以上三个文件夹,我们还有会用到的文件夹如下:
Define —— 用于存放我们设置的一些宏(#define)。
Model —— 用于存放模型类(数据模型)。
NetworkManager —— 用于存放网络请求类
Resources —— 用于存放资源 例如xib,s

3.5 实现MVVM模式4.总结1.Caliburn.Micro框架介绍Caliburn.Micro(地址)作为一款非常流行的开源WPF MVVM框架,是一个轻量级、强大且灵活的框架,旨在帮助开发者更容易地在多种应用程序中实现MVVM(Model-View-ViewModel)模式,掌握他可以让我们的WPF开发效率更高,框架采用MIT宽松许可,可以免费商用。2.Caliburn.Micro主要特点简化MVVM实现:Caliburn.Micro专注于简化视图与视图模型的交互,处理事件绑定、命令执行、依赖注入等常见的MVVM场景。它提供了视图与视图模型之间的自动绑定约定,只要视图的名称视图模型的名称遵循约定,Caliburn.Micro会自动关联它们。自动绑定机制:通过内置的ActionMessage,Caliburn.Micro可以简化事件命令绑定。开发者可以在视图的XAML中直接绑定到视图模型中的方法,而不需要依赖于ICommand。依赖注入支持:Caliburn.Micro支持与依赖注入容器集成,允许开发者在应用程序中使用IoC容器(如SimpleInjector、Autofac等)进行对象的自动创建管理,从而简化了复杂应用程序中的依赖管理。导航管理:在构建多页面应用时,Caliburn.Micro提供了简便的导航管理功能,帮助开发者处理视图视图模型的生命周期。通过ConductorScreen类型,可以轻松管理多个页面或子视图。协程支持:Caliburn.Micro支持协程,通过在视图模型中定义方法的返回值为IEnumerable,可以将复杂的异步操作以协程的方式进行处理,从而增强了异步编程的可读性。3.如何使用3.1 Caliburn.Micro安装首先创建空的WPF程序:选择基于.NET Framework的WPF应用:选择.NET Framework 4.6.2框架,实际上Caliburn.Micro框架既支持.NET Framework框架,也支持跨平台的.net core平台。使用Nuget管理器安装Caliburn.Micro框架选择管理NuGet程序包:点击浏览,输入Caliburn.Micro:选择Caliburn.Micro,点击安装:安装好后,我们在项目的引用中看到已安装的库:至此,Caliburn.Micro已经成功安装。3.2 配置BootstrapperBootstrapper翻译为引导程序,他是最先启动的,引导WPF程序启动,我们新建一个Bootstrapper类,该类继承自BootstrapperBase,一般我们在该类里面实例化IoC容器,订阅全局未处理的异常,同时选择最先启动的视图模型,Bootstrapper类的代码如下:internal class Bootstrapper : BootstrapperBase{ private SimpleContainer _container; public Bootstrapper() { // 订阅全局未处理异常 AppDomain.CurrentDomain.UnhandledException += CurrentDomain_UnhandledException; Initialize(); } private void CurrentDomain_UnhandledException(object sender, UnhandledExceptionEventArgs e) { // 可以选择写入日志文件,或者打印到控制台窗口 Console.WriteLine(e); } protected override void Configure() { _container = new SimpleContainer(); _container.Singleton<IEventAggregator, EventAggregator>(); _container.Singleton<IWindowManager, WindowManager>(); _container.PerRequest<MainWindowViewModel>(); } protected override void OnStartup(object sender, StartupEventArgs e) { DisplayRootViewForAsync<MainWindowViewModel>(); } protected override object GetInstance(Type service, string key) { return _container.GetInstance(service, key); } protected override IEnumerable<object> GetAllInstances(Type service) { return _container.GetAllInstances(service); } protected override void BuildUp(object instance) { _container.BuildUp(instance); } protected override void OnUnhandledException(object sender, DispatcherUnhandledExceptionEventArgs e) { // 可以选择写入日志文件,或者打印到控制台窗口 Console.WriteLine(e.Exception); e.Handled = true; // 设置已处理异常,防止应用程序崩溃 }}1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253在上面的示例中,我们创建了Bootstapper类,订阅了全局未处理异常事件,此处订阅了两处未处理异常事件,一个是复写了BootstrapperBase提供的OnUnhandledException虚函数,该虚函数仅能处理UI线程触发的未捕获异常,对于其他线程未捕获的异常,我们通过订阅AppDomain.CurrentDomain.UnhandledException来进行处理。同时,我们选择了MainWindowViewModel作为程序的启动视图模型,在Caliburn.Micro框架中,所有视图模型都需要继承自PropertyChangedBase,以下是MainWindowViewModel的相关代码:internal class MainWindowViewModel : PropertyChangedBase{}1233.3 配置App.xamlApp类作为WPF的启动类,原始的App.xaml如下:可以看到,原始App.xaml最先启动MainWindow.xaml,要想让Caliburn.Micro接管整个启动流程,我们需要对App.xaml进行一些更改,让程序最先启动Bootstrapper类,App.xaml按照如下代码进行修改:<Application x:Class="CaliburnMicroDemo.App" xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:local="clr-namespace:CaliburnMicroDemo"> <Application.Resources> <ResourceDictionary> <ResourceDictionary.MergedDictionaries> <ResourceDictionary> <local:Bootstrapper x:Key="Bootstrapper" /> </ResourceDictionary> </ResourceDictionary.MergedDictionaries> </ResourceDictionary> </Application.Resources></Application>1234567891011121314将StartupUri="MainWindow"进行删除,然后添加了<local:Bootstrapper x:Key=“Bootstrapper” />,这样Bootstrapper就接管了WPF的启动流程。3.4 创建视图视图模型先运行一下程序,看看实际效果:
最新发布
04-04
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值