Skip to main content

MVVM and MVP pattern(s) as applicable to SilverLight


There could be more to these design patterns and its applicability in SilverLight, however this article is only intended to present and overview and high-level understanding of how to get started in SilverLight application patterns.

SilverLight implements SOLID design guidelines along with a MVVM or MVP design pattern.
Figure shown below  depicts the comparison of approaches followed in MVVM and MVP pattern.




MVVM pattern can follow two approaches

1.       View First: The view is responsible for creating an instance of a ViewModel, via databinding to a static resource or setting the data context in the code-behind file.
  • Databinding approach

UserControl.Resources
local:SampleViewModel x:Key=”ViewModel” /
UserControl.Resources
                Grid DataContext=”{Binding Path=Object,
Grid is bound to object that is obviously in Model.


  • Code Behind approach
 this.DataContext = new SampleViewModel();

2.       View-Model first: The ViewModel creates an instance of the view and sets its data context.
This is usually done using an Inversion of Control Container like MEF, PRISM etc.
(This  article is only an exploration of design patterns in use in silverlight)
Both these approaches have their own pros and cons that I am not going to discuss here. For the time it’s your decision based on requirement as to which approach you want to follow.

Event Broker Pattern:
The normal way to use an event is for one class to subscribe to the events of another class. This approach works great when each class has direct access to the other and only one class can trigger an event. 

However, in more advanced scenarios one or more classes may need to send the same event or be notified by events without subscribing directly to the caller event.

Events can be treated as another type of dependency and instead of subscribing directly to an event, a container (Event Broker) could be used to manage the subscribers and publishers of an event. This is  exactly what is done in IOC /Dependency injection .
When an event occurs, the Event Broker would be responsible for notifying all subscribers that an event occurred.

Let’s consider a practical example of  handling the closing of an application.
Normal Scenario:  The application needs to loop through each control on the screen to check to see if its needs to be saved before applications closes.
Event Broker Pattern Scenario:
Event Broker handles notification to each control, to save itself. Isn’t his a better approach.

Hope this was helpful.

Till Next we connect……

Happy reading……

Comments

Popular posts from this blog

Asp.Net 4.0: An Overview-Part-III

This is the last post in the series which will explore the following new features of ASP.Net 4.0  Performance Monitoring for Individual Applications in a Single Worker Process Web.config File Refactoring Permanently Redirecting a Page Expanding the Range of Allowable URLs Performance Monitoring for Individual Applications in a Single Worker Process It is a common practice to host multiple ASP.NET applications in a single worker process, In order to increase the number of Web sites that can be hosted on a single server. This practice results in difficulties for server administrators to identify an individual application that is experiencing problems. ASP.NET 4 introduces new resource-monitoring functionality introduced by the CLR. To enable this functionality, following XML configuration snippet is added to the aspnet.config configuration file.(This file is located in the directory where the .NET Framework is installed ) <?xml version="1.0" encoding="UTF-8...

WCF-REST Services-Part-II

HOW REST is implemented in WCF Part-I of the series explored the REST conceptually and this post will explore how REST is implemented in WCF. For REST implementation in WCF, 2 new attributes namely WebGetAttribute and WebInvokeAttribute are introduced in WCF along with a URI template mechanism that enables you to declare the URI and verb to which each method is going to respond. The infrastructure comes in the form of a binding ( WebHttpBinding ) and a behavior ( WebHttpBehavior ) that provide the correct networking stack for using REST. Also, there is some hosting infrastructure help from a custom Service¬Host ( WebServiceHost ) and a ServiceHostFactory ( WebServiceHostFactory ). How WCF Routes messages WCF routes network messages to methods on instances of the classes defined as implementations of the service. Default behavior ( Dispatching ) for WCF is to do this routing based on the concept of action. For this dispatching to work, an action needs to be present in ev...

WPF Routing

WPF (3.5) introduced the concept of Routing that made the event routing easies in the scenarios where it was tedious to handle events. Consider a scenario where there are a number of Hyperlinks in a Panel that direct to separate locations on Click. Now if this is done in normal programming, each hyperlink will have to have code for execution. It would be easier and cleaner if we could handle the hyperlinks in the container (the Panel) that handles the click and redirects to appropriate location. WPF handles the events with the following 3 strategies. Direct events are like ordinary .NET events. They originate in one element and don’t pass to any other. For example, MouseEnter is a direct event. Bubbling events are events that travel up the containment hierarchy. For example, MouseDown is a bubbling event. It is raised first by the element that is clicked. Next, it is raised by that element’s parent, and then by that element’s parent, and so on, until WPF reaches the top of the e...