Har*_*ess 17
在Windows窗体或没有MVVM的WPF中,你可以说MessageBox.Show()就是这样!如果你能在MVVM中做同样的事情,那不是很好吗?
这是一种方法 - 它就像我可以到达MessageBox.Show()一样接近.
这是MVVM友好的MessageBox_Show()!
public class MyViewModel: ViewModelBase
{
protected void AskTheQuestion()
{
MessageBox_Show(ProcessTheAnswer, "Are you sure you want to do this?", "Alert", System.Windows.MessageBoxButton.YesNo);
}
public void ProcessTheAnswer(MessageBoxResult result)
{
if (result == MessageBoxResult.Yes)
{
// Do something
}
}
}
Run Code Online (Sandbox Code Playgroud)
田田!
下面是它的工作原理:
MessageBox_Show实际上所做的就是激活一个事件,因此它非常适合MVVM.ViewModel对任何可能使用或不使用它的视图一无所知,并且它不会自己执行Windows MessageBox的显示,因此它也可以安全地进行单元测试.
要在View中使用它,这将导致它实际显示MessageBox,您只需订阅该事件并在事件处理程序中调用e.Show(),如下所示:
public partial class MyView : UserControl
{
public MyView()
{
InitializeComponent();
this.DataContext = new MyViewModel();
(this.DataContext as MyViewModel).MessageBoxRequest += new EventHandler<MvvmMessageBoxEventArgs>(MyView_MessageBoxRequest);
}
void MyView_MessageBoxRequest(object sender, MvvmMessageBoxEventArgs e)
{
e.Show();
}
}
Run Code Online (Sandbox Code Playgroud)
这就是显示MVVM友好的Windows MessageBox所需要做的全部内容.
下面的代码只需要在项目中实现一次,或者您可以将其放在可重用的共享库中.
将其添加到ViewModel基类中,以便可以从任何ViewModel使用它:
public class ViewModelBase : INotifyPropertyChanged
{
//...
public event EventHandler<MvvmMessageBoxEventArgs> MessageBoxRequest;
protected void MessageBox_Show(Action<MessageBoxResult> resultAction, string messageBoxText, string caption = "", MessageBoxButton button = MessageBoxButton.OK, MessageBoxImage icon = MessageBoxImage.None, MessageBoxResult defaultResult = MessageBoxResult.None, MessageBoxOptions options = MessageBoxOptions.None)
{
if (this.MessageBoxRequest != null)
{
this.MessageBoxRequest(this, new MvvmMessageBoxEventArgs(resultAction, messageBoxText, caption, button, icon, defaultResult, options));
}
}
}
Run Code Online (Sandbox Code Playgroud)
然后为事件处理程序添加EventArgs类:
public class MvvmMessageBoxEventArgs : EventArgs
{
public MvvmMessageBoxEventArgs(Action<MessageBoxResult> resultAction, string messageBoxText, string caption = "", MessageBoxButton button = MessageBoxButton.OK, MessageBoxImage icon = MessageBoxImage.None, MessageBoxResult defaultResult = MessageBoxResult.None, MessageBoxOptions options = MessageBoxOptions.None)
{
this.resultAction = resultAction;
this.messageBoxText = messageBoxText;
this.caption = caption;
this.button = button;
this.icon = icon;
this.defaultResult = defaultResult;
this.options = options;
}
Action<MessageBoxResult> resultAction;
string messageBoxText;
string caption;
MessageBoxButton button;
MessageBoxImage icon;
MessageBoxResult defaultResult;
MessageBoxOptions options;
public void Show(Window owner)
{
MessageBoxResult messageBoxResult = MessageBox.Show(owner, messageBoxText, caption, button, icon, defaultResult, options);
if (resultAction != null)resultAction(messageBoxResult);
}
public void Show()
{
MessageBoxResult messageBoxResult = MessageBox.Show(messageBoxText, caption, button, icon, defaultResult, options);
if (resultAction != null) resultAction(messageBoxResult);
}
}
Run Code Online (Sandbox Code Playgroud)
单元测试很简单:
target.AskTheQuestion();
target.ProcessTheAnswer(System.Windows.MessageBoxResult.Yes);
Run Code Online (Sandbox Code Playgroud)
快乐的编码!
我发现MVVM在程序员中调用了一连串的强迫症(我从经验中知道).这是好事.但是对于某些事情来说,努力是不值得的,特别是如果它引入了整个复杂的顺序,只是问用户"你确定你想要xxxx吗?"
我的观点是MessageBox.Show()可以从代码隐藏中调用,但从不调用ViewModel.在对话框与XAML更好地集成之前,只需点击即可,并且不要为此感到沮丧.它实际上是WPF UI设计当前状态的灰色区域.
| 归档时间: |
|
| 查看次数: |
39621 次 |
| 最近记录: |