一、前言 在MVVM編程的模式中,有時候我們會遇到一個很尷尬的情況: 若幹個xaml.cs都復用一個ViewModel,當ViewModel想傳遞一個特定的消息給某一個xaml.cs的時候,我們該怎麼做? 或者當一個.cs不方便在另一個.cs文件中new出來使用,但是我確實想傳遞消息給那個.cs,該 ...
一、前言
在MVVM編程的模式中,有時候我們會遇到一個很尷尬的情況:
若幹個xaml.cs都復用一個ViewModel,當ViewModel想傳遞一個特定的消息給某一個xaml.cs的時候,我們該怎麼做?
或者當一個.cs不方便在另一個.cs文件中new出來使用,但是我確實想傳遞消息給那個.cs,該怎麼辦?
今天就說說MVVM Light中的Messager類,它繼承自IMessager介面。
二、使用方法
發送頁面中:
Messenger.Default.Send<TMessage>(TMessage message); //第一種方法 Messenger.Default.Send<TMessage>(TMessage message, object token);//第二種方法 Messenger.Default.Send<TMessage, TTarget>(TMessage message);//第三種方法
一般來說用第一種就足已:(裡面的T可以是各種類型)
我這裡this是傳的頁面本身,可以自己決定傳當前頁面的特有部分: this.your_property 或者 this.your_method等等
Messenger.Default.Send<GenericMessage<T>>(new GenericMessage<T>(this, value));
接收頁面中:
Messenger.Default.Register<GenericMessage<T>>(this, Your_Action); private void Your_Action(GenericMessage<T> msg) { // do with msg }
msg會包含發送頁面的value,這樣我就可以對msg進行相關的處理。
三、各種情況
一個發送頁面,一個頁面接收時: 即第二部分的例子
一個發送頁面,多個頁面接收時: 在各自的接收頁面中需要對msg進行過濾,獲取該接收頁面需要的消息。
多個發送頁面,多個頁面接收時: 每個發送頁面可以設定T,即消息的類型,只要接收頁面在Register的時候用對應的類型即可接收到自己想要的Send頁面。
四、總結
在MVVM中其實還是少用這些Messager類,它會使代碼顯得不具有可讀性,又使程式的代碼佈局顯得不清晰。因為你在一個頁面中使用Messager.Default.Send時,其他人看你代碼是不方便找到在哪裡Register的。它不像我們平時兩個頁面只要引用一下就可以F12快速的跟蹤過去。只有在你實在沒辦法的時候再去考慮Messager類。