我正在使用 MVVM Light 开发 WPF/MVVM 应用程序。现在我ViewModelLocator
的很标准;它包括一个static
构造函数,该构造函数通过注册 ViewModelSimpleIoc
并具有返回 ViewModel 的当前实例的属性。
我不知道这有多合适,但我一直在探索使用ViewModelLocator
ViewModels 中的实例来访问其他 ViewModels 的属性并更改ContentControl
我的一个视图。如果这样做有任何重大问题,请告诉我,以便我找到解决方法。例如,我可能在 ViewModel 中有一些东西,例如:
private ViewModelLocator _viewModelLocator = new ViewModelLocator();
private void SomeMethod()
{
_viewModelLocator.OtherViewModel.SomeProperty = something;
}
在不同的 ViewModel 中,我有以下内容:
private ViewModelLocator _viewModelLocator = new ViewModelLocator();
public ViewModelBase CurrentViewModel { get; set; }
private void SomeMethod()
{
CurrentViewModel = _viewModelLocator.SomeViewModel;
}
在这种情况下,在我看来CurrentViewModel
是必然的。ContentControl
目前能够做到这一点非常方便,但我想从更有经验的程序员那里得到一些意见,以确保我不会自欺欺人。如果它有问题,我可以采取更多可接受的路线来达到相同的结果吗?
现在,如果上述方法没有任何问题,我想知道制作ViewModelLocator
static
. 为了尝试一下,我快速切换到static
ViewModelLocator
. 在我的 MainWindow.xaml 中,我将其设置DataContext
为:
DataContext="{Binding Source={x:Static vm:ViewModelLocator.Main}}"
...回到第一个例子,我可以使用:
private void SomeMethod()
{
ViewModelLocator.OtherViewModel.SomeProperty = something;
}
和:
public ViewModelBase CurrentViewModel { get; set; }
private void SomeMethod()
{
CurrentViewModel = ViewModelLocator.SomeViewModel;
}
现在该程序使用 a 可以正常工作static
ViewModelLocator
,但它还处于起步阶段,所以我想知道这是否是未来可行的选择,或者我是否应该完全远离 a static
ViewModelLocator
。
对于这些问题的任何建议或意见将不胜感激。我对编程还很陌生,我想学习从长远来看对我有用的技术。
如果我在这里所做的事情没有明显的问题,也请告诉我。
谢谢。