WPF框架Prism中使用MVVM架構
常見的MVVM框架
眾所周知, 如果你了解WPF當中的ICommand, INotifyPropertyChanged的作用, 就會發(fā)現眾多框架都是基于這些進行擴展, 實現其通知、綁定、命令等功能。
對于不同的MVVM框架而言, 大體使用上會在聲明方式上的差異, 以及特定功能上的差別。
下面列舉了常用的3個MVVM框架,他們的一些差異。如下所示:
| 功能↓ / →框架名 | Prism | Mvvmlight | Micorosoft.Toolkit.Mvvm |
| 通知 | BindableBase | ViewModelBase | ObservableObject |
| 命令 | DelegateCommand | RelayCommand | Async/RelayCommand |
| 聚合器 | IEventAggregator | IMessenger | IMessenger |
| 模塊化 | √ | × | × |
| 容器 | √ | × | × |
| 依賴注入 | √ | × | × |
| 導航 | √ | × | × |
| 對話 | √ | × | × |
正如你所見, 各個框架之間都有各自的通知、綁定、事件聚合器等基礎的功能, 而Prsim自帶的依賴注入、容器、以及導航會話等功能, 可以為你提供更加強大的功能。
當然,在實際的開發(fā)過程當中, 可以根據實際的功能需求, 對不同的框架選型, 同時這也需要你對各個框架之間的優(yōu)缺點進行判斷。
那么, 下面將主要介紹Prism當中的通知、綁定等功能。
BindableBase
如果在此之前, 你用類型mvvmlight框架, ViewModel繼承的類如下:
public class TestViewModel : ViewModelBase
{
private string _message;
public string Message
{
get { return _message; }
set { _message = value; RaisePropertyChanged(); }
}
}在Prism當中, 你需要繼承于BindableBase, 如下所示:
public class TestViewModel : BindableBase
{
private string _message;
public string Message
{
get { return _message; }
set { _message = value; RaisePropertyChanged(); }
}
}Command
在mvvmlight/microsoft.toolkit.mvvm中, 聲明Command,如下:
public class TestViewModel : ViewModelBase
{
public RelayCommand SendCommand { get; set; }
public RelayCommand<string> SendMessageCommand { get; set; }
}在Prism當中, 你可以使用DelegateCommand及帶參數的Command, 如下:
public class TestViewModel : ViewModelBase
{
public DelegateCommand SendCommand { get; set; }
public DelegateCommand<string> SendMessageCommand { get; set; }
}CompositeCommand
對于單個Command而言, 只是觸發(fā)單個對應的功能, 而復合命令是Prism當中非常強大的功能, CompositeCommand簡單來說是一個父命令, 它可以注冊N個子命令, 如下所示:

當父命令被激活, 它將觸發(fā)對所有的子命令, 如果任意一個命令CanExecute=false,它將無法被激活,如下所示:

IEventAggregator
- 松耦合基于事件通訊
- 多個發(fā)布者和訂閱者
- 微弱的事件
- 過濾事件
- 傳遞參數
- 取消訂閱
該功能主要作用為, 事件聚合器負責接收訂閱以及發(fā)布消息。訂閱者可以接收到發(fā)布者發(fā)送的內容。
例如: AViewModel訂閱了一個消息接收的事件, 然后BViewModel當中給指定該事件推送消息,此時AViewModel接收BViewModel推送的內容。如下所示:

示例,下面演示如何創(chuàng)建訂閱及發(fā)布:
//創(chuàng)建事件
public class SavedEvent : PubSubEvent<string> { }
//發(fā)布
IEventAggregator.GetEvent<SavedEvent>().Publish("some value");
//訂閱
IEventAggregator.GetEvent<SavedEvent>().Subscribe(.Subscribe(message=>
{
//do something
});Filtering Events
在實際的開發(fā)過程當中,我們往往會在多個位置訂閱一個事件, 但是對于訂閱者而言, 他并不需要接收任何消息, 如下所示:

在Prism當中, 我們可以指定為事件指定過濾條件, 如下所示:
eventAggregator.GetEvent<MessageSentEvent>()
.Subscribe(arg =>
{
//do something
},
ThreadOption.PublisherThread,
false,
//設置條件為token等于“MessageListViewModel” 則接收消息
message => message.token.Equals(nameof(MessageListViewModel)));關于Subscribe當中的4個參數, 詳解:
- 1.action: 發(fā)布事件時執(zhí)行的委托。
- 2.ThreadOption枚舉: 指定在哪個線程上接收委托回調。
- 3.keepSubscriberReferenceAlive: 如果為true,則Prism.Events.PubSubEvent保留對訂閱者的引用因此它不會收集垃圾。
- 4.filter: 進行篩選以評估訂閱者是否應接收事件。
Unsubscribe
為注冊的消息取消訂閱, Prism提供二種方式取消訂閱,如下:
1.通過委托的方式取消訂閱
var event = IEventAggregator.GetEvent<MessageSentEvent>(); event.Subscribe(OnMessageReceived); event.Unsubscribe(OnMessageReceived);
2.通過獲取訂閱者token取消訂閱
var _event = eventAggregator.GetEvent<MessageSentEvent>(); var token = _event.Subscribe(OnMessageReceived); _event.Unsubscribe(token);
到此這篇關于WPF框架Prism中使用MVVM架構的文章就介紹到這了。希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
ASP.NET性能優(yōu)化之讓瀏覽器緩存動態(tài)網頁的方法
上一篇《ASP.NET性能優(yōu)化之構建自定義文件緩存》我們通過OutputCache,讓請求去訪問服務器asp.net的輸出緩存,我們擴展了OutputCacheProvider,這相當于是訪問服務器上的靜態(tài)資源。2011-09-09
asp.net 動態(tài)生成rdlc報表(原創(chuàng))
因為公司需求 研究微軟的Reportviewer 因為有許多特別要求所以動態(tài)調用 比較靈活 我的需求是 根據數據不同的合并表頭 (參考了隨心所欲的博客文檔 再次表示感謝)2011-12-12
asp.net中“從客戶端中檢測到有潛在危險的Request.Form值”錯誤的解決辦法
這篇文章主要介紹了asp.net中“從客戶端中檢測到有潛在危險的Request.Form值”錯誤的解決辦法,需要的朋友可以參考下2015-11-11
詳解.Net Core + Angular2 環(huán)境搭建
這篇文章主要介紹了詳解.Net Core + Angular2 環(huán)境搭建,具有一定的參考價值,有興趣的可以了解一下。2016-12-12
使用Visual Studio 2017作為Linux C++開發(fā)工具
這篇文章主要為大家詳細介紹了使用Visual Studio 2017作為Linux C++開發(fā)工具的相關資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-03-03
ASP.NET Core中實現用戶登錄驗證的最低配置示例代碼
最近工作中遇到一個需求,需要在ASP.NET Core中來實現一個基礎的身份認證,下面這篇文章主要給大家介紹了關于ASP.NET Core中實現用戶登錄驗證的最低配置的相關資料,需要的朋友可以參考借鑒,下面來一起看看吧。2017-10-10
Asp.net 文件上傳類(取得文件后綴名,保存文件,加入文字水印)
Asp.net 取得文件后綴名,保存文件,加入文字水印的代碼類2008-11-11

