这篇文章主要给大家介绍了关于MVVM简化的Messager类的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
前言
在开发Wpf/SL应用时,经常会遇到不同页面和窗体之间的参数传递的问题。对于这类问题,我们一般通过事件实现数据传递,也可以定义全局静态变量来进行数据共享。这里我们则使用了另外一种非常高效而优雅的方法来进行消息传递,这里我称之为Messenger,事实上,Messenger并非mvvm的专利,我们可以把它看作一种设计模式,你可以在其它.net程序中使用它。
简化Messager类
看MVVMLight的Messager源码,自己实现了一个简单的Messager类。
Messager类可以在MVVM中,实现View与VM、VM与VM、View与View的通信。
public class Messager { private static Messager _MessageInstance; private Dictionary_MessageCollection=new Dictionary (); private Dictionary _MessageTCollection = new Dictionary (); 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 (string key, Action action) { ActionClass actionClass = new ActionClass (); actionClass.action = action; _MessageTCollection.Add(key, actionClass); } public void Send(string key) { if (_MessageCollection.Keys.Contains(key)) { _MessageCollection[key].Invoke(); } } public void Send (string key,T para) { if (_MessageTCollection.Keys.Contains(key)) { ActionClass actionClass=(ActionClass ) _MessageTCollection[key]; actionClass.action.Invoke(para); } } }
主要通过Register方法来注册,Send方法来触发。
比如,VM中需要显示一个窗体,为了不破坏MVVM模式,我们可以把显示窗体的方法写在View中,并注册到Messager
Messager.Default.Register("ChangeControlShow", ExecuteChangedContrlShow); private void ExecuteChangedContrlShow(string msg) { //some code... }
在VM中调用
Messager.Default.Send("ChangeControlShow","test");
Send有两个参数,第一个是方法的Key,根据这个Key,可以找到唯一的方法,第二个参数是需要调用的方法的参数。
这样,你只要知道方法的key,在任何文件中,都可以调用注册的方法,不需要我们再去使用委托了。
总结
以上就是MVVM简化的Messager类实例代码的详细内容,更多请关注0133技术站其它相关文章!