看MVVMLight的Messager源码,自己实现了一个简单的Messager类。
Messager类可以在MVVM中,实现View与VM、VM与VM、View与View的通信。
<pre>
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);
}
}
}
</pre>
比如,VM中需要显示一个窗体,为了不破坏MVVM模式,我们可以把显示窗体的方法写在View中,并注册到Messager
<pre>
Messager.Default.Register<string>("ChangeControlShow", ExecuteChangedContrlShow);
private void ExecuteChangedContrlShow(string msg)
{
//some code...
}
</pre>
在VM中调用
<pre>
Messager.Default.Send<string>("ChangeControlShow","test");
</pre>
Send有两个参数,第一个是方法的Key,根据这个Key,可以找到唯一的方法,
第二个参数是需要调用的方法的参数。
这样,你只要知道方法的key,在任何文件中,都可以调用注册的方法,不需要我们再去使用委托了。
网友评论