快速上手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));

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值