The SimpleIoc addition in the most recent version of MVVMLight is a great add and really simplifies the ViewModelLocator across all of the platforms supported in this framework.
If you are not familiar with MVVM Light or what types of project platforms it supports please go to http://mvvmlight.codeplex.com
or www.galasoft.ch/mvvm to learn more.
However if you are using the Messenger Service in MVVM Light to perform a set of actions to do the following:
- User takes an action
- Application changes views
- Application send message to display or load data
Then it is important to note that there are some differences in the way that the ViewModels are loaded in comparison to the previous version of MVVM Light.
Let's look at the ViewModelLocator in the new version:
public class ViewModelLocator
ServiceLocator.SetLocatorProvider(() => SimpleIoc.Default);
Justification = "This non-static member is needed for data binding purposes.")]
public MainViewModel Main
Notice that in comparison to what you may have seen in the past version, there is a single property to the ViewModel and a simple line in the constructor
here to register the ViewModel with the Ioc Container and that is it.
The property for the ViewModel is Lazy, meaning that it is loaded on demand and is a singleton. You can create multiple instances
by passing in a key upon creation, but for this example I'll keep it simple.
Given the scenario above you will get the result of the secondary view not getting the message sent event though you have registered the message with
the Message Service and have an action ready to handle it. BUT the second time through it's fine and operates as it should. What has happened?
Very simply, the examples you have seen in the past very rarely ever cover situations in the real world nor do they ever go far enough to look at the overloads in the constructor etc.
What has happened here is that the ViewModel must exist first in order to take action on the message. Moreover, the Messenger Service in MVVM Light
does not operate like a Service Bus or Message Queue where the messages stay there until they are read. It is more similar to Events, a fire and forget model.
In order to alleviate said problem, simple pass in "true" to the Register call in the SimpleIoc to create the instance
of the ViewModel immediately and go on with your coding.
The previous version of MVVM Light created all of the ViewModels immediately, although not too much of an issue; there are instances where a user may not
go to every view in the application and the idea here is to only load what is needed and keep the View and ViewModels loaded in memory when necessary.
If you have questions please comment and/or contact me on twitter @spboyer.
Shayne Boyer aka TattooCoder, has been developing Microsoft based solutions for the last 15 years. Currently working as a Solutions Architect focused on Services Oriented Architecture and in his spare time runs the Orlando Windows Phone and Windows 8 User Group. He is a passionate developer and loves to talk about his craft, teach and also learn from others.
- MCSD .NET
- Telerik MVP
- Orlando Windows Phone & Metro User Group Founder (@OrlandoWPUG)
- INETA Speaker
- DZone.com MVB