天天看點

【MVVM Light】Messager的使用

一、前言

      在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類。