首先,如果这很简单,我必须道歉。我是WPF和MVVM的新手,我想确保自己没有违反任何WPF或MVVM概念。此外,对于以下冗长的解释(尝试提供所有详细信息):
我当前正在引用具有所有业务逻辑或服务层(服务类,实体类,数据操作等)的Assembly dll。
这在其他传统的Windows Forms应用程序中使用。我现在正在创建一个新的桌面WPF应用程序(早期),我必须使用相同的程序集。
我用菜单,状态栏等及其ViewModel(称为_mainViewModel)创建了一个主窗口。
我创建了另一个具有自己的ViewModel对象的简单窗口(称为_abcViewModel)。 Windows对象/控件在子视图中绑定良好。效果很好,到目前为止,我对此感到满意。
_abcViewModel使用了程序集中的逻辑,该逻辑可以使用传统的委托和事件处理程序来检索某些消息。
现在,我的意图是将来自这些事件的消息绑定到主窗口StatusBar对象,该对象绑定到_mainWindowViewModel.StatusBarItemMessage。我怎样才能做到这一点?
我从另一个stackoverflow帖子(:How to access WPF MainWindow Controls from my own .cs file)中发现,您可以使用以下方法访问主窗口对象: (((MainWindow)System.Windows.Application.Current.MainWindow)._ mainWindowViewModel.StatusBarMessage = args.Message;
我在_abcViewModel中订阅了这些DLL事件处理程序:
private void SubscribeBusinessLogicEvents()
{
_SPPIDDrawingWPFService.PidToolBoxInfoEvent += new SPPIDDrawingWPFService.PidToolBoxInfoEventHandler(PidToolBoxInfoEvent);
_SPPIDDrawingWPFService.PidToolBoxErrorEvent += new SPPIDDrawingWPFService.PidToolBoxErrorEventHandler(PidToolBoxErrorEvent);
}
private void UnsubscribeBusinessLogicEvents()
{
_SPPIDDrawingWPFService.PidToolBoxInfoEvent -= PidToolBoxInfoEvent;
_SPPIDDrawingWPFService.PidToolBoxErrorEvent -= PidToolBoxErrorEvent;
}
internal void PidToolBoxErrorEvent(object sender, PidToolBoxEventArg args)
{
App.WriteLocalErrorLogFile(args);
}
internal void PidToolBoxInfoEvent(object sender, PidToolBoxEventArg args)
{
//Is this correct? Can I change Main Windows view model from here?
((MainWindow)System.Windows.Application.Current.MainWindow)._mainWindowViewModel.StatusBarItemMessage = args.Message;
if (args.OptionalPopUpFlag)
{
//
}
App.WriteWoodEngSysToolBoxErrorLog(args);
}
这是正确的方法吗?从其他ViewModel访问ViewModel是否打破了Model–view–viewmodel或MVVM的概念?
如何从子窗口执行的操作中更新主窗口状态栏控件。我不想在所有窗口上都使用庞大的ViewModel对象。
任何帮助/建议将不胜感激。 谢谢
答案 0 :(得分:0)
查看事件聚合。您的MainWindowViewmodel应该订阅AbcViewModel广播的“事件”。这样会将AbcViewModel与MainWindowViewModel分离。
Prism是实现此模式的库。该库可能无法满足您的需求,但是您可以轻松实现自己的系统。
您的用法可能类似于:
AbcViewModel.cs
internal void PidToolBoxInfoEvent(object sender, PidToolBoxEventArg args)
{
_eventAggregator.GetEvent<PidToolBoxUpdateEvent>().Publish(args);
App.WriteWoodEngSysToolBoxErrorLog(args);
}
MainWindowViewModel.cs
public class MainWindowViewModel
{
public MainWindowViewModel(IEventAggregator ea)
{
// You may need to subscribe on the UI thread.
// If so, use: Subscribe(..., ThreadOption.UIThread)
ea.GetEvent<PidToolBoxUpdateEvent>().Subscribe(UpdateStatusBar);
}
void UpdateStatusBar(PidToolBoxEventArg pidEventArgs)
{
//implement logic
}
}