可借助WPF Community Toolkit(含MVVM Toolkit)大幅减少样板代码:一、安装CommunityToolkit.Mvvm包;二、用[ObservableProperty]自动生成通知属性;三、用[ICommand]声明命令;四、用WeakReferenceMessenger实现松耦合通信;五、通过DI注册并注入IMessenger等服务。

如果您在C# WPF项目中采用MVVM模式开发,但发现手动实现INotifyPropertyChanged、ICommand绑定、状态管理等逻辑重复繁琐,则可借助WPF Community Toolkit(含MVVM Toolkit)大幅减少样板代码。以下是具体使用方法:
一、安装MVVM Toolkit NuGet包
该步骤为使用Toolkit的前提,需将核心库引入项目以启用源生成器与基础类型支持。确保项目目标框架为.NET 6或更高版本。
1、在Visual Studio中右键解决方案资源管理器中的项目,选择“管理NuGet程序包”。
2、切换到“浏览”选项卡,搜索并安装CommunityToolkit.Mvvm包(注意:无需安装Wpf或WinUI专属包,此包为跨平台MVVM核心)。
3、确认安装完成后,项目文件中应包含类似
二、定义可绑定视图模型类
MVVM Toolkit通过源生成器自动实现INotifyPropertyChanged和ObservableObject功能,避免手写OnPropertyChanged调用,提升类型安全性和性能。
1、新建一个C#类,例如命名为MainViewModel,并继承ObservableObject基类。
2、使用[ObservableProperty]特性标记私有字段,如private string _title;。
3、保存文件后,源生成器将自动生成public string Title { get; set; }及对应通知逻辑,无需手动调用SetProperty。
三、声明命令并绑定到UI
Toolkit提供ICommand的轻量封装,支持异步命令、参数化执行及自动启用/禁用状态同步,消除DelegateCommand或RelayCommand的手动实现。
1、在视图模型中添加私有方法,例如void OnSaveClicked()或async Task OnLoadAsync()。
2、使用[ICommand]特性修饰该方法,生成对应ICommand属性(如SaveCommand)。
3、在XAML中绑定Command="{Binding SaveCommand}",点击时自动触发方法,且当方法含async Task签名时,命令会自动禁用直至任务完成。
四、使用Messenger进行松耦合通信
替代传统事件聚合器,Messenger提供类型安全的发布-订阅机制,避免内存泄漏与强制转换,适用于跨模块消息传递。
1、在发送方视图模型中调用WeakReferenceMessenger.Default.Send(new NotificationMessage("DataUpdated"))。
2、在接收方(如另一个ViewModel或View代码后台)注册监听:WeakReferenceMessenger.Default.Register
3、确保在接收方Dispose或OnDetached中调用Unregister,或使用强引用注册时配合生命周期管理。
五、配置依赖注入与服务定位
Toolkit不绑定特定DI容器,但提供IDispatcherQueue、IMessenger等抽象接口,便于在不同宿主环境(WPF/WinUI)中统一获取服务实例。
1、在App.xaml.cs的OnStartup中,调用Microsoft.Extensions.DependencyInjection.ServiceCollectionExtensions.AddCommunityToolkitServices(services)扩展方法注册默认服务。
2、在ViewModel构造函数中声明IMessenger或IDispatcherQueue参数,由DI容器自动注入。
3、若未使用DI,也可直接访问WeakReferenceMessenger.Default静态实例进行快速通信。










