快速上手Prism WPF 工程
1、Prism 介绍
- 定位:
Prism 是 微软推出的框架,专为构建 模块化、可维护的复合式应用程序 设计,主要支持 WPF、Xamarin.Forms、UWP 等平台。 - 核心功能:
- 模块化开发:将应用拆分为独立模块,按需加载。
- 导航管理:处理页面导航和参数传递。
- 事件聚合:通过事件总线实现松耦合的组件通信。
- 依赖注入集成:支持多种 DI 容器(如 Unity、DryIoc、Autofac)。
- 与 DI 容器的关系:
Prism 不直接提供 DI 容器,但提供接口(IContainerRegistry
和IContainerProvider
)来集成第三方容器(如 Unity 或 DryIoc)。
2、Prims 模版扩展安装
在Visual Studio 2022 管理扩展中加载
3、Prism - Unity 和 DryIoc选择
Unity
- 定位:
Unity 是 微软开发的依赖注入容器,属于 Enterprise Library 的一部分,功能全面但较为重量级。 - 核心功能:
- 依赖注入:支持构造函数注入、属性注入、方法注入。
- 生命周期管理:单例、瞬态、作用域等生命周期控制。
- 扩展性:支持自定义扩展(如拦截器、策略)。
- 性能:
早期版本性能较低,但最新版本(Unity 5+)已优化。 - 适用场景:
适合企业级应用,尤其是需要复杂依赖管理和扩展性的项目。
DryIoc
- 定位:
DryIoc 是 轻量级、高性能的依赖注入容器,以极快的解析速度著称。 - 核心功能:
- 极速解析:通过优化代码生成和缓存实现高性能。
- 简洁 API:配置简单,学习成本低。
- 零依赖:无外部库依赖,适合轻量化项目。
- 高级功能:支持条件注册、装饰器、元数据等。
- 性能:
在基准测试中通常比 Unity 快 2-10 倍。 - 适用场景:
适合对性能敏感的应用(如游戏、高频服务)或需要轻量级 DI 容器的场景。
4、创建Prism工程
文件>新建项目
5、工程目录结构
- Prism 完整应用程序 - 此项目模板创建一个 Prism 应用程序,其中包含一个 Shell 项目、一个模块项目、一个核心项目、一个服务项目和一个单元测试项目。
6、核心对象介绍
BindableBase 数据与行为绑定对象
简介
BindableBase 是 Prism 中实现 数据绑定通知 的核心基类,继承自 INotifyPropertyChanged 接口。它简化了属性变更通知的触发逻辑,确保 UI 能够自动响应数据变化。
作用与特性
自动触发通知:通过 SetProperty 方法设置属性值,自动触发 PropertyChanged 事件。
减少样板代码:避免手动编写 if (value != field) { ... } 和事件触发逻辑。
支持派生类:ViewModel 通常继承 BindableBase,直接使用其功能。
关键方法
SetProperty(ref T field, T value):基础属性设置。
SetProperty(ref T field, T value, Action onChanged):设置属性并执行回调。
RaisePropertyChanged(string propertyName):手动触发指定属性的通知。
IContainerRegistry IContainerProvider
IContainerRegistry
:用于注册服务(接口与实现的映射)。IContainerProvider
:用于解析(获取)已注册的服务实例。public MainViewModel(IContainerProvider containerProvider){var service = containerProvider.Resolve<IMessageService>();}
注册方式
# 接口绑定实现类:
containerRegistry.Register<IMessageService, MessageService>();
#直接注册具体类(无需接口):
containerRegistry.Register<MessageService>();#单例(Singleton):全局唯一实例。
containerRegistry.RegisterSingleton<IMessageService, MessageService>();
#瞬态(Transient):每次解析创建新实例。
containerRegistry.Register<IMessageService, MessageService>();#实例注册:直接注入已有实例。
var logger = new FileLogger();
containerRegistry.RegisterInstance<ILogger>(logger);#同一个接口多个实现,注册时加别名containerRegistry.Register<IMessageService, MessageService>("msg");
containerRegistry.Register<IMessageService, EmailMessageService>("emailMsg");
注入方式
#1、构造函数注入 **推荐
private readonly ILogger _logger;
private readonly IEventAggregator _eventAggregator;public MessageService(IEventAggregator eventAggregator, ILogger logger)#2、属性注入[Dependency]
public ILogger Logger { get; set; }
IEventAggregator
在Prism框架中,事件总线(Event Aggregator) 是实现松耦合跨组件通信的核心机制。它通过发布-订阅模式(Pub-Sub)让不同模块、视图或服务之间无需直接引用即可传递消息,尤其适用于模块化架构和MVVM模式。
核心组件 直接依赖注入
# 使用流程# 定义事件
// 有参事件
public class NoMicDeviceEvent : PubSubEvent<bool> { }
// 无参事件
public class AppExitEvent : PubSubEvent{ }# 发布事件// 发布有参事件
_eventAggregator.GetEvent<NoMicDeviceEvent>().Publish(true);// 发布无参事件
_eventAggregator.GetEvent<AppExitEvent>().Publish();# 订阅事件// 订阅事件(自动强引用,需手动取消订阅)
_eventAggregator.GetEvent<NoMicDeviceEvent>().Subscribe((bo) => HandleNoMicDeviceEvent(bo));// 处理事件的回调方法
private void HandleNoMicDeviceEvent(bool isNoMic)
{//处理逻辑
}# 订阅参数
.Subscribe(Action<TPayload> action, // 回调方法ThreadOption.UIThread, // ThreadOption threadOption 在UI线程执行keepSubscriberReferenceAlive: false, // 弱引用Predicate<TPayload> filter: // 过滤数据
#参数#回调方法
#执行具体的业务逻辑(如更新数据库、刷新UI)。#filter
#过滤无关事件(如只处理特定用户或状态的数据)。#keepSubscriberReferenceAlive
#控制订阅者生命周期(View/ViewModel用弱引用,服务层可强引用)。#ThreadOption
#PublisherThread:在发布事件的线程执行(默认)。
#UIThread:在UI线程执行(安全更新界面)。
#BackgroundThread:在线程池后台线程执行(避免阻塞UI)
#解决跨线程问题(UI操作必须在UI线程,耗时操作在后台线程)。# 卸载事件
_eventAggregator.GetEvent<NoMicDeviceEvent>().Unsubscribe((bo) => HandleNoMicDeviceEvent(bo));