I think that I have found one of the best articles on MVVM that I have ever read:
This article sums up what is in MVVM and what is outside of MVVM. Note, when I and most other people say MVVM, they really mean MVVM, Commanding, Dependency Injection + any other Patterns you need to create your application.
In WPF a lot of use is made of the Decorator and Behaviour pattern as well. The goal of all of this is to have pure separation of concerns. This is what every code behind file of every Control / Window / Page should look like if you are engineering your WPF and Silverlight correctly:
public partial class IdealView : UserControl
{
public IdealView()
{
InitializeComponent();
}
}
Figure: This is the ideal code behind for a Control / Window / Page when using MVVM.
public partial class IdealView : UserControl
{
public IdealView()
{
InitializeComponent();
this.DataContext = new IdealViewModel();
}
}
Figure: This is a compromise, but the best you can do without Dependency Injection
Partial Public Class ServerExplorerConnectView
End Class
Figure: This is the ideal code behind for a Control / Window / Page when using MVVM.
Partial Public Class ServerExplorerConnectView
Private Sub ServerExplorerConnectView_Loaded(ByVal sender As Object, ByVal e As System.Windows.RoutedEventArgs) Handles Me.Loaded
Me.DataContext = New ServerExplorerConnectViewModel
End Sub
End Class
Figure: This is a compromise, but the best you can do without Dependency Injection
Technorati Tags: .NET WPF Silverlight MVVM
If you've made it this far, it's worth connecting with our principal consultant and coach, Martin Hinshelwood, for a 30-minute 'ask me anything' call.
We partner with businesses across diverse industries, including finance, insurance, healthcare, pharmaceuticals, technology, engineering, transportation, hospitality, entertainment, legal, government, and military sectors.
NIT A/S