看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,在任何文件中,都可以调用注册的方法,不需要我们再去使用委托了。