看MVVMLight的Messager源碼,自己實現了一個簡單的Messager類。
Messager類可以在MVVM中,實現View與VM、VM與VM、View與View的通信。
public class Messager { private static Messager _MessageInstance; private Dictionary<string,Action> _MessageCollection=new Dictionary<string,Action> (); private Dictionary<string, ActionClass> _MessageTCollection = new Dictionary<string, ActionClass>(); public static Messager Default { get { if (_MessageInstance == null) { _MessageInstance = new Messager(); } return _MessageInstance; } } public void Register(string key,Action action) { _MessageCollection.Add(key,action); } public void Register<T>(string key, Action<T> action) { ActionClass<T> actionClass = new ActionClass<T>(); actionClass.action = action; _MessageTCollection.Add(key, actionClass); } public void Send(string key) { if (_MessageCollection.Keys.Contains(key)) { _MessageCollection[key].Invoke(); } } public void Send<T>(string key,T para) { if (_MessageTCollection.Keys.Contains(key)) { ActionClass<T> actionClass=(ActionClass<T>) _MessageTCollection[key]; actionClass.action.Invoke(para); } } }
主要通過Register方法來注冊,Send方法來觸發。
比如,VM中需要顯示一個窗體,為了不破壞MVVM模式,我們可以把顯示窗體的方法寫在View中,並注冊到Messager
Messager.Default.Register<string>("ChangeControlShow", ExecuteChangedContrlShow); private void ExecuteChangedContrlShow(string msg) { //some code... }
在VM中調用
Messager.Default.Send<string>("ChangeControlShow","test");
Send有兩個參數,第一個是方法的Key,根據這個Key,可以找到唯一的方法,
第二個參數是需要調用的方法的參數。
這樣,你只要知道方法的key,在任何文件中,都可以調用注冊的方法,不需要我們再去使用委托了。