The MVVM Design Pattern

Download as pdf or txt
Download as pdf or txt
You are on page 1of 7

This DZone Refcard is brought to you by...

Love being connected, all over again

The experience is elegant. The platform is powerful. One free download gives you the tools to build new, or tweak existing, Silverlight and XNA applications and games for Windows Phone 7. Discover the possibilities.

http://create.msdn.com

brought to you by...

#135
Get More Refcardz! Visit refcardz.com
CONTENTS INCLUDE:
n n

Overview MVVM Explained MVVM on Windows Phone MVVM Project Templates VVM Commands Hot Tips and more...

A Formula for Elegant, Maintainable Mobile Apps


By Colin Melia

The MVVM Design Pattern

OVERVIEW

If you are developing a Silverlight application for the Windows Phone, then this Refcard is probably for you. For all but the most trivial of applications, the Model-View-ViewModel (MVVM) pattern provides a solid pattern to follow for building a wellstructured and maintainable application. Microsoft has taken that message seriously with Windows Phone by basing three of the four Visual Studio application project templates on the MVVM pattern. This card provides an explanation of the MVVM pattern, how its supported and how to follow it on Windows Phone. As a side benefit, the content is almost entirely applicable to Silverlight desktop, web, slate and Windows Presentation Foundation (WPF) applications as well.

Model

Why MVVM on Windows Phone?

MVVM is an architecture pattern introduced by John Gossman in 2005 specifically for use with WPF as a concrete application of Martin Fowlers broader Presentation Model pattern. Implementation of an application, based on the MVVM patterns, uses various platform capabilities that are available in some form for WPF, Silverlight desktop/web, and on Windows Phone with a little help from other libraries. Many commercial applications, including Microsoft Expression products, were built following MVVM. The benefits of MVVM are listed as follows and can be largely summed up in the phrase Separation of Concerns.
Modular architecture: given good inter-layer interface definitions, components can be built and well tested independently. Loose coupling: with one-way dependencies, changes to one layer dont require the other to be changed, rebuilt or retested. Role separation: responsibilities and expertise can be focused (e.g., designers can build UI without needing to write code). Tool friendly: the design of the pattern and the capabilities of the platform mean that different tools best suited to the skills of the user can be used. These tools include Visual Studio for developers and Blend for UI designers.

The Model is the object model for the application. It can also be the layer for data and/or business logic that are completely devoid of UI features and any dependency on the platform UI libraries or runtime. It can hold state and/or perform processing on the state relevant to the business/problem domain. The data or the operations performed on the data may be dealt with entirely in process memory (e.g., the current value of rolled dice), or they may be retrieved, stored and processed remotely using a data repository/service (e.g., a database or web service) with the model in memory representing a subset of the available data (e.g., specific customer records).

Hot Tip
View

By creating a Model that is not bound to a single platform, it is easier to share the data model across Silverlight, WPF and WP7 platforms with the potential for reuse of model documentation, direct code or even binary libraries. Recommend basing MVVM development on Silverlight 3 to ease code sharing with WP7, Silverlight 3/4 and WPF 4.

The View is a layer that represents and handles all the UI elements, including both displayed UI (e.g., classic buttons and more sophisticated displays) and UI-user interactions (e.g., screen touch, button press, etc.). There can be several Views over the same data with varying detail, depth or representation (e.g., summary + details, order +. order + order line items, charting).

The MVVM Design Pattern

Maintainability: as with other patterns, a well-structured design makes it easier to make modifications when updates or upgrades are done. Less coding: the separation also leads to areas of development with less code, which means less room for error; it also means less regression testing when changes are made. Testability: the pattern enables automated unit testing of code and minimizes the need for UI-based testing.

Hot Tip

The MVVM pattern is not a set of all-or-nothing rules that one must strictly adhere to. It may not be appropriate for all applications, especially small ones where implementing MVVM may require too much overhead.

MVVM EXPLAINED

Get the free tools

Introduction

The MVVM pattern encourages developers to build their application as three layers with the dependencies shown.
DZone, Inc.
|

www.dzone.com

The MVVM Design Pattern: A Formula for Elegant, Maintainable Moble Apps

One of the capabilities a platform needs to enable the MVVM pattern well is the ability to create UI declaratively with text instead of code. Those declarations can include parts that bind visual elements to data available in the Model, such that value or list changes stay in sync between the View and Model data. This minimizes or replaces imperative code for settings values between the View elements and data in the Model. Also, since code in the UI can be difficult to test (with automation), this reduces or eliminates the amount of UI-updating-related code to be tested. The concept of binding can also be used to bind a user-driven event to an action to be performed against the data in the Model. Creation of a View declaratively also opens up the possibility that someone with good design/interactivity sensibilities can design the View (perhaps with a more designer-focused tool) without coding/library expertise and somewhat independently from the software developer.

MVVM pattern, select File->New Project in Visual Studio, select Silverlight for Windows Phone from the Installed Templates and then select one of the template types. To build from scratch, select Windows Phone Application or see the section below about MVVM support in other templates.

Model

The Model is based on a CLR type from a simple value type as a property
public int Value { get; set; }

to a more complex set of nested classes, e.g., Contact


public enum PhoneType { Work, Home, Mobile } public class PhoneNumber { public String Number { get; set; } public PhoneType PhoneType { get; set; } } public class Contact { public String Name { get; set; } public List<PhoneNumber> PhoneNumbers { get; set; } }

ViewModel

While a View can be bound to the data in the Model or actions against that data, in practice this is not done directly but via another layer called the ViewModel or VM. It is a Model of the View since it is like an abstraction of the View (with UI code) but also a specialization of the Model that the View can bind to. Creation of the ViewModel may be appropriate because:
It may be that the Model code is not controlled by a developer and also does not expose data in a way that allows a View to be bound to it. In this case, the ViewModel wraps the Model data to expose in a way that allows for declarative binding with update notifications. The Model may have data types that may not directly match the types used by the UI components/libraries (e.g., a boolean value on the Model may need to become a visibility enumeration specific to the UI libraries). In this case, the ViewModel wraps the Model and performs the conversion between the View and Model via the IValueConverter interface when data binding. There are other complex operations beyond conversion to be performed that are not UI related but dont necessarily belong in the Model for the business/problem domain (e.g., some kind of Aggregation or Visualization computation). Having this code in the ViewModel means its easier to test. The state of UI selection needs to be stored and tracked, but this does not belong in the Model.

A Model may be placed in a separate class file or project/ assembly, or (as is often the case for simple cases) it may be incorporated into the ViewModel.

ViewModel

The ViewModel is a CLR class (typically in a separate class file and sometimes in a separate assembly) that encapsulates the Model or incorporates it. If the Model includes nested objects or collections of objects, then a corresponding ViewModel class hierarchy may be created. The primary goal is to expose the Model data and actions on the model data to the View for binding. If the View only takes values from the ViewModel once at initialization, there would be nothing more to do. But typically, the UI updates to reflect value and collection changes in the ViewModel data (and possibly vice versa, e.g., for TextBox changes). The built-in UI controls for single values on Windows Phone (e.g. TextBlock, TextBox, etc.) used in the View are amongst the controls that look for the INotifyPropertyChanged interface on classes to which they are bound; therefore, the interface should be implemented on the ViewModel. It consists of just one event, and it is standard practice to create a helper method to fire the event, which is then called by the setter method of the properties as they are changed. Using INotifyPropertyChanged in a class requires this statement.
using System.ComponentModel;

The ViewModel is also usually responsible for initiating operations to retrieve and store Model data, which allows it to track operation state and, therefore, expose visual feedback or state information to which the View can bind. The actual operation (and obtaining progress) may be delegated to Model-specific classes.

Inter-Layer Dependency

By deliberately having the ViewModel in the middle, the following becomes possible:
The View only knows about the ViewModel. It does not know about, nor does it have any reference to or dependency on, the Model. The reverse is also true; therefore, the Model and View can be maintained separately using the ViewModel as the buffer. The ViewModel only knows about the Model. It does not know about the View. Therefore, new views can be added without affecting the ViewModel. Given the use of binding, it may even be possible to update the ViewModel without breaking the View. The Model only knows about itself. It does not know what ViewModels are wrapping it or what Views are created on top of the ViewModels. In any case, all layers share a common knowledge of and are tightly coupled to the basic types/objects of the underlying platform.

A ViewModel incorporating a simple Model with non-nested/ collection properties may look like this:
public class MyValueVM : INotifyPropertyChanged { private int Value; public int MyProperty { get { return Value;} set { if( Value == value ) return; Value = value; OnPropertyChanged(Value); } } private void OnPropertyChanged(String PropName) { if(PropertyChanged != null) PropertyChanged(this, new PropertyChangedEventArgs(PropNa me)); } } public event PropertyChangedEventHandler PropertyChanged;

MVVM ON WINDOWS PHONE

Hot Tip

For the latest release of the free Windows Phone developer tools, go to http://create.msdn.com/. A complete guide to building and deploying a simple MVVM-based WP7 application for the marketplace is available - http://bit.ly/WP7Die.

To start creating a Windows Phone application based on the


DZone, Inc.
|

www.dzone.com

The MVVM Design Pattern: A Formula for Elegant, Maintainable Moble Apps

Remember that the integer named Value is the Model data in this class. When the property setter method for Value is called, it checks to see if there is a change. If so, calls the helper method that will inform the View (if bound to that object and property) that something has changed. If a Model contains a collection of items that can change and the UI must update to reflect those changes, the collection must implement the INotifyCollectionChanged interface. Alternatively, use the Generic ObservableCollection<T> class to do the work, which requires this include statement:
using System.Collections.ObjectModel;

public partial class MainPage : PhoneApplicationPage { public MainPage() { this.DataContext = new CustomerVM(); InitializeComponent(); } }

2. Per View/page creation in the page/UserControl XAML, for example with this XML namespace at the top of the View page
xmlns:myapp=clr-namespace:MyAppNamespace

and this resource XAML inside the page root element

A ViewModel called MyValuesVM (note the s) containing Model data that is a Collection of objects of type MyValueVM would then look like this:
public class MyValuesVM : INotifyPropertyChanged { private ObservableCollection<MyValueVM> Values; public ObservableCollection<MyValueVM> MyProperty { get { return Values;} set { if( Values == value ) return; Values = value; OnPropertyChanged(Values); } } private void OnPropertyChanged(String PropName) { if(PropertyChanged != null) PropertyChanged(this, new PropertyChangedEventArgs(Prop Name)); } public event PropertyChangedEventHandler } PropertyChanged;

<phone:PhoneApplicationPage.Resources> <myapp:CustomerVM x:Key=MyCustomerVM/> </phone:PhoneApplicationPage.Resources>

and the DataContext set on a FrameworkElement item.


<Grid x:Name=TopGrid DataContext={StaticResource MyCustomerVM}> </Grid>

3. Per Application instance in this case, the ViewModel (and possibly a hierarchy of nested ViewModels) is created in the App.xaml XAML as a resource (as above), and then parts of it are bound as the DataContext at the root of different Views. This makes sense when the Model data must be available throughout the applications lifetime. 4. Using a ViewModel locator in the XAML. The DataContext of each view is bound to properties of an application-instance-bound object using the Path syntax. When the property of the root ViewModel is retrieved (following the View-specific Path) for binding, the getter method can dynamically hand out an instance of the appropriate ViewModel. Combine this with dependency injection and mock encapsulated Models (when the application-instance-bound object is created) for a powerful way to dynamically assign real or mock ViewModels and Models, thus providing support for ViewModel testing, web-service-based Model integration testing and design-time visual designer editing.

In this case, the following changes would be notified to the View:


The whole collection is set Membership of the collection changes The Value property on individual MyValueVM items change

Hot Tip

Keep Models encapsulated rather than incorporated into ViewModels to enable clean dependency injection testing using mock Models.

View - Binding

Hot Tip

If a Model has nested/collection objects and the UI needs to bind to changes in the properties of those objects and there is access to the Model code, then it be may easier to incorporate the model/classes into a hierarchy of ViewModel classes. Otherwise (if the Model is not editable), then access to data change events from the Model is needed to fire the PropertyChanged event. To help catch otherwise silent runtime binding notification errors, the helper function could be augmented with a reflection-based check to ensure the PropName passed in matches an actual property.

With the DataContext property correctly set on the FrameworkElement-derived visual element, various properties can be bound to properties (or descendent properties) of the DataContext object. This can be done programmatically or declaratively. Given a set of ViewModels like this (with notification helpers and calls omitted for brevity)
public class CustomerVM { public String ID { get; set; } public String Name { get; set } public ContactPreferencesVM Preferences { get; set; } } public class ContactPreferencesVM { public Boolean CanCall { get; set; } public Boolean CanEmail { get; set; } }

View - DataContext

The View layer in Silverlight applications can be implemented in code or declaratively using XAML (where, simply put, at initialization, elements become objects and attributes becomes properties). For Windows Phone, the View is a typically a PhoneApplicationPage or a UserControl. Any object used in the View that inherits from FrameworkElement (i.e., the visual controls) has a DataContext property which can be set to a .NET object. Any descendent FrameworkElement in the visual tree of the XAML page will also have the same value for its DataContext unless explicitly overridden (in which case its nested XAML descendants have that new value, and so on). The DataContext is typically created and set in one of 4 ways:
1. Per View/page creation in the page/UserControl constructor (the xaml.cs file), for example: DZone, Inc.
|

The declarative XAML excerpt may look like this


<StackPanel Orientation=Horizontal Name=TopPanel> <TextBlock Text={Binding ID}/> <StackPanel> <TextBox Text={Binding Name, Mode=TwoWay}/> <StackPanel Orientation=Horizontal DataContext={Binding Preferences}> <CheckBox IsEnabled={Binding CanEmail}/> <CheckBox IsEnabled={Binding CanPhone}/> </StackPanel> </StackPanel> </StackPanel>

which shows how to use inherited and explicit descendent DataContext and the basic binding syntax.

www.dzone.com

The MVVM Design Pattern: A Formula for Elegant, Maintainable Moble Apps

The example also shows different data binding options (below) with TwoWay being applicable to a TextBox where the updated should be transferred back to the ViewModel to set the Model data.
Mode
OneTime OneWay (default) TwoWay

Hot Tip

Build on these templates and create custom Visual Studio templates for increased team productivity http://msdn.microsoft.com/en-us/library/6db0hwky.aspx.

Effect in MVVM
ViewModel property value copied to View element upon initialization. Seldom used, but could help performance. ViewModel property value copied to View element upon initialization and when ProperyChanged event called. Same as one way, plus value copied back from View element to ViewModel property triggering event various by visual element type.

Quick Guide to the MVVM Project Templates

The information in the previous sections together with the following guide to MVVM pattern use in the provided templates should help bring clarity to basic use of MVVM on Windows Phone.
A single instance of the ViewModel called MainViewModel (incorporating Model data) is created using the singleton pattern and exposed as the ViewModel property on the App object in the App. xaml.cs file. The ViewModel class is defined under the ViewModels folder. It has a collection of ItemViewModel objects implemented using ObservableCollection. MainPage is the primary View and its DataContext is set in code to App.ViewModel in the pages constructor in MainPage.xaml.cs. For the Databound Application, the DataContext for the DetailsPage View is set in code to an item in the App.ViewModel.Items collection in the pages constructor in DetailsPage.xaml.cs.

View Collection Binding

When the ViewModel exposes model data as a collection, use a control in the View that derives from ItemsControl (e.g., ListBox) and set the ItemsSource to the collection. The control creates a sub-visual tree for each object in the collection and automatically sets its DataContext to the item object. ItemsControls have an ItemTemplate property, which can be set in XAML to a collection of XAML visual elements (including the bindings) to represent visually each object in the collection, for example:
<ItemsControl DataContext={Binding MyContact} ItemsSource={Binding PhoneNumbers}> <ItemsControl.ItemTemplate> <DataTemplate> <StackPanel Orientation=Horizontal> <TextBlock Text={Binding Number}/> </StackPanel> </DataTemplate> </ItemsControl.ItemTemplate> </ItemsControl>

Hot Tip

Consider separating Models, Views and ViewModels into separate folders in Visual Studio Solution Explorer.

VVM COMMANDS

Introduction

Hot Tip

Overall, using data binding and other View model coupling (shown later) reduces or eliminates UI code that can otherwise be hard to test when driven by user actions.

View - Converters

When Model types dont match View types (e.g., Enumeration type to String), the ViewModel can do the conversation or a converter can be used. To create a converter, create a class derived from System.Windows.Data.IValueConverter and implement Convert() and ConvertBack(), declare an instance of the class in the page (or application) resource (as with ViewModel creation case 2 above) and then add the converter to the binding syntax, for example.
<StackPanel Orientation=Horizontal> <TextBlock Text={Binding Number}/> <TextBlock Text={Binding PhoneType, Converter={StaticResource MyPhoneTypeToStringConverter}}/> </StackPanel>

In order to take actions (e.g., load/save data), perform operations (e.g., compute some results) or perform some navigation, a method is needed to convert a user interaction event within the View (button press, touch, etc.) into a method call on the ViewModel class. This is done by exposing Commands on the ViewModel that, when executed, either perform the action in the ViewModel or delegate it to the Model or some other library.

ICommand

A command is implemented as an object property on the ViewModel (which can be bound to by the View) that supports the ICommand interface that is defined on Windows Phone under System.Windows.Input.
public interface ICommand { bool CanExecute(Object parameter); void Execute(Object parameter); event EventHandler CanExecuteChanged; }

Hot Tip

Use Converts (vs. conversion in ViewModel) if they are reusable and relate to UI on one end, not for transforming business data.

MVVM PROJECT TEMPLATES

The Execute() method is self explanatory. The CanExecute() method is provided so that a visual element bound to the object can query whether execution is currently possible and potentially update itself visually to indicate the state. The CanExecuteChanged event should be raised by the ViewModel whenever the ability execute or not has changed. On the interaction side, there needs to be a way to connect user interactions with exposed commands. Silveright controls have events to which code-based event handlers can be attached, but this is UI code that is hard to test. In the Silverlight platform for the desktop/web, the controls derived from ButtonBase (e.g., Button) have a Command property which can be bound to the ICommand-based object properties on the ViewModel, and the Button works with the ICommand interface as one would expect. However, these are not implemented in Silverlight 3 and Silverlight for Windows Phone.

Project templates based on MVVM

Three of the project templates included with the free Windows Phone developer tools, as indicated, are based on MVVM.

DZone, Inc.

www.dzone.com

The MVVM Design Pattern: A Formula for Elegant, Maintainable Moble Apps

MVVM Light

In addition to no direct ICommand support in Windows Phone for controls to bind to commands, exposing potentially many command objects, with each one as a private class nested inside the ViewModel class can be quite time-consuming and verbose. While its technically possible to improve these two issues by creating helper classes (to make exposing commands easier) and creating Behaviours (to bind UI events to commands) that can be used in code, XAML and XAML-based tools like Blend, it makes sense to use available third-party libraries to accelerate this process. One such library is part of the MVVM Light toolkit available from GalaSoft - http://www.galasoft.ch/mvvm/installing/manually/ or use NuGet. To use MVVM Light libraries to easily expose commands in a concise way:
1. Add a reference to Galasoft.MvvmLight.WP7.dll, Galasoft.MvvmLight. Extras.WP7.dll & System.Windows.Interactivity.dll that come in the toolkit 2. In the ViewModel class file, add:
using GalaSoft.MvvmLight.Command;

OTHER MVVM LIBRARIES

Using MVVM Libraries

As shown, the MVVM Light toolkit (for WP7, Silverlight and WPF on CodePlex) is easy to start with and also includes other features:
A ViewModelBase class Messenger system for inter-ViewModel communication Visual Studio project and item templates Visual Studio code snippets

Hot Tip

To ease implementation, consider inheriting ViewModels from a library base class (or create one), including support for the INotifyPropertyChanged interface inheritance/implementation and helper functions.

Caliburn Micro

Calibrun Micro is a small but powerful micro-framework for WP7, Silverlight and WPF on CodePlex that supports MVVM development including these features:
ActionMessages for flexible binding of UI actions to ViewModel methods (achieving what Commands do) Bootstrapper & ViewLocator for pattern configuration and handing out ViewModels to Views Screens and Conductors for tracking active screens and selections

3. Expose a property of type RelayCommand on the ViewModel:


public RelayCommand MyCommand { get; private set; }

4. Create a private method that performs the command


private void DoMyCommand() { // Do command }

Prism

5. In the ViewModel constructor, instantiate the command so that it calls the private method when Execute() is called on ICommand by the UI.
private void DoMyCommand() { // Do command }

Prism 4 is a free library from Microsoft Patterns & Practices group for WP7, Silverlight and WPF, originally concerned with building composite application. It includes a WP7 library with helpful features (including MVVM support):
Commands with DelegateCommand similar to RelayCommand in MVVM Light. Pub/sub eventing Run-time data template selection Application Bar helpers UI Interaction Helpers

6. Optionally, add a second lambda expression to the RelayCommand constructor that will be checked when CanExecute() is called on ICommand by the UI. 7. If necessary, call RaiseCanExecuteChanged() on the command object when the ability to execute the command changes, so that bound UI knows to call CanExecute() to update any visual cues. 8. Repeat steps 3 to 7 for each command to be exposed.

Hot Tip

Read the in-depth Windows Phone 7 Developer Guide from Microsoft Patterns & Practices to see Prism is a use in sample MVVM-based application http://msdn.microsoft.com/en-us/library/gg490765.aspx

To use the libraries to bind control events (e.g., a single touch that is equivalent to a left mouse button down) to exposed commands in XAML (while writing no code):
1. Add the MVVM Light namespace at the others at the top of the XAML
xmlns:i=clr-namespace:System.Windows.Interactivity;assembly=System. Windows.Interactivity xmlns:mvvmextra=clr-namespace:GalaSoft.MvvmLight. Command;assembly=GalaSoft.MvvmLight.Extras.WP7

BLENDABILITY

Making WP7 MVVM applications blendable

The free tools for Windows Phone include a version of Blend that can be used for design. Blend has a UI optimized for UI design, over coding. If a developer produces ViewModel and Model classes, a UI designer can then produce interactive UI in Blend and bind to the ViewModel, producing XAML in the project that can then be loaded back into Visual Studio. Blend (and the Visual Studio XAML designer) actually instantiates the XAML and calls the constructor of the page class (i.e., the View). This may cause the ViewModel to also be instantiated. For Blend (and Visual Studio) to work well with MVVM-based applications for designing there are a few guidelines to follow:
Dont call web services or database in the View or ViewModel constructor the designer may not load. To see the design of the UI, try to use XAML over code, since controls added programmatically will not show up. Instantiate empty collections in constructors so they can be bound to.

2. Add this XAML like this inside the controls element


<i:Interaction.Triggers> <i:EventTrigger EventName=MouseLeftButtonDown> <mvvmextra:EventToCommand Command={Binding MyCommand}/> </i:EventTrigger> </i:Interaction.Triggers>

3. Optionally, if the control has an IsEnabled property to be set according to the CanExecute property and CanExecuteChanged event on the ICommand-enabled object, set the MustToggleIsEnabledValue to True, e.g.
<mvvmextra:EventToCommand Command={Binding MyCommand} MustToggleIs EnabledValue=True/>

4. Repeat 2 to 3 for all controls to be bound to exposed commands.

DZone, Inc.

www.dzone.com

The MVVM Design Pattern: A Formula for Elegant, Maintainable Moble Apps

If possible, use the full ViewModelLocator pattern to allow switching at design-time to mock ViewModels with design data or mock Models injected into the ViewModel. If that route doesnt suit, then at least consider using design data (see below).

Hot Tip

To detect if the application is in a designer tool, use System.ComponentModel.DesignerProperties.IsInDesignTool

HttpWebRequest/Response class, or service proxy class inc. OData proxies) or if data is stored locally, this would involve classes under System.IO and System.IO.IsolatedStorage or thirdparty databases (e.g., Sterling DB or Perst). If properties are serializable, it may be convenient to just serialize the ViewModel and Model state using classes under System.Xml.Serialization. Having an application-instance-based object with one or more ViewModel properties may provide a convenient ViewModel hub for all the pages in your application.

Design Data

The project templates in the tools that support MVVM also show examples of design-time data under the SampleData folder. Since XAML can fundamentally be used to declare objects and properties, it can be used to declare sample ViewModels (including nested object/collection properties). By using the d:DataContext (with the design-time namespace prefix) in XAML (see MainPage. xaml in the Data Bound application), the DataContext can be set on the page or sub-element to use the static sample data.

Tombstoning

An application may have volatile session-specific Model data (e.g., data entry in progress and not yet saved) and/or View Model UI state that can be lost if the application is tombstoned (de-activated by the OS to preserve foreground application performance or to perform another task and possibly never re-activated). ViewModels should subscribe under PhoneApplicationService to the Deactived event and use its Current.State dictionary to save this transient state on Deactivated and load back (if necessary/ available) in both the ViewModel constructor and the Activated event, the transient data along with any non-session-specific data. See more on tombstoning on MSDN: http://msdn.microsoft.com/en-us/library/ff817008(v=VS.92).aspx

Hot Tip

A designer using Blend to build UI on top of ViewModel classes provided by a developer can use a feature in Blend that automatically generates XAML sample data based on the class properties of the ViewModel or Model as well as generate XAML sample data based on XML files.

PERSISTENCE

Data persistence

A ViewModel should wrap the action of saving/loading data it represents (which may be delegated to a Model class). This may use a web service (using the WebClient class, the

Hot Tip

When using MVVM with TextBox controls bound to data, use something like the Prism UpdateTextBindingOnPropertyChanged class in XAML to ensure all Text changes are transferred through the binding prior to a tombstone or Application bar event.

ABOUT THE AUTHOR


Colin Melia is the Principal Architect for Ace of Clouds as well as a speaker, trainer, author, user group leader, academic advisor, CTO, and company director. He has expertise creating rich UI with WPF/Silverlight, cloud development with Azure, mobile development on Windows Phone, and business intelligence with SQL Server. He has in-depth knowledge of core technologies such as .NET, OData, WCF, WF, LINQ, and WIF.

RECOMMENDED BOOKS
Programming Windows Phone 7 is a free e-book from Charles Petzold and the Windows Phone 7 team. This book is divided into 3 parts: basic concepts of Windows Phone 7, Silverlight, and XNA 2D.

READ NOW
http://www.charlespetzold.com/phone/

#82
Get More Refcardz! Visit refcardz.com
CONTENTS INCLUDE:

About Cloud Computing Usage Scenarios Underlying Concepts

Cost by... Data Tier Technologies t to you ply. brough Platform Management and more... te. Com bora

Aldon
Chan ge. Colla

#6 Cloud 4Computing
By Daniel Rubio
also minimizes the need to make design changes to support CON TEN TS one time events. INC

Getting Started with

Browse our collection of over 100 Free Cheat Sheets


Upcoming Refcardz
Core HTML
By An dy Ha rris

Vis it

ION EGRAT

w ww.dzone.com

Re fca

rd z!

Pay only what you consume

Ge t

Mo re

Cloud Computing

expand

s on

efer ion the not

e.com

Ge t Mo re

ref c

E: INC LUD gration NTS ous Inte Change CO NTE Continu at Every ns About Software i-patter Build and Ant Patterns Control ment Version e... Manage s and mor Build Practice Build

to isolat space n e Work riptio itory a Desc These companies have Privat deployed webmanage applications are in long trol repos to n-con lop softw ing and Deve a versio that adapt and scale to large user bases, making them rn les to ize merg Patte it all to minim space Comm many aspects related tomultiple computing. s cloud e Work knowledgeable in a mainline Privat that utilize lop on Deve code lines a system sitory of work active Repo are within units This Refcard will introduce to you to clouddcomputing, with an softw riente loping ine task-o e Deve Mainl es you emphasis oncodelines providers, so by Commit better understand these softwar chang Level can S INT e code ding Task what it is a cloud computingaplatform can offer your web INUOU trol ut line Policy nize sourc es as of buil Orga Code e witho it chang cess CONT ion con e name sourc subm T applications. and it the pro jects vers are from with uniqu ABOU softw (CI) is um the build evel Comm build a pro minim Label Task-L ies to gration ed to activit blem the bare ion ate all cies to t ous Inte committ USAGE SCENARIOS to a pro Autom congurat nden ymen Build depe al tion deplo t Continu ry change ive manu Label d tool nmen the same stalle , a solu , ineffect ) Build eve t, use target enviro ated s (i.e. ce pre-in blem with ymen Redu Autom ns (i.e. ory. d deploEAR) in each lar pro that pattern ticu tagge via or cies -patter s reposit t nden For each (e.g. WAR es lained ) and anti the par solution duce al Depe ge t Web application deployment untillibrari yearsenvironmen similar x packa Minim be exp nden a few target ago was text ns are d to to pro all rity all depe CI can ticular con alizeplans with le that y Integ es use Anti-patter they tend es, but can to late alloted resources, with an Centr Binar most phone services: ts etim , temp s. nt nmen ctic in a par hes som geme t enviro e a single based on incurred cost whether such resources were consumedto thenot. or proces in the end bad pra enting Creat cy Mana nt targe es rties are rily nden implem approac ed with the cial, but, chang prope Depe into differe itting er necessa pared to e te builds e comm late Veri associat to be ben befor are not Cloud computing asRun remo its known etoday has changed this. etc. Temp n com Build ually, They Privat contin lts whe appear effects. rm a The various resources consumed by webperiodically, applications (e.g.nt team Perfo opme ed resu d Builds sitory Build gration to devel Repo Stage adverse unintend bandwidth, memory, CPU) areIntegration on from CI server basis tallied a per-unit e ous Inte e Build rm an ack produc Privat . Continu Refcard feedb on (starting from zero) by Perfomajor cloud computing platforms. all ated occur pattern based tion autom as as they the term cycle, this the builds Build gra Send of soon such ration ion with ors as Integ entat ous Inte tional use and test concepts docum oper Continu conven build include the rate devel to to the s Gene While of CI

Re fca

rdz !

on: grati s s Inte -Patternvall nuou d Anti Paul M. Du By ContiPatterns an


ABOUT CLOUD COMPUTING

dz. com

ref car

Web applications have always been deployed on servers connected to what is now deemed the cloud. However, the demands and technology used on such servers has changed substantially in recent years, especially with the entrance of service providers like Amazon, Google and es Microsoft. e chang

Vis it

ation Having the capability to support one time events, cloud Useful Open computing platforms also facilitate the gradual growth curves Page Source Stru Tools faced by web applications. cture Key

HTML Automated growth & scalable technologies vs XHT


HTML

Basics

LUD E:

Valid

ML

ents and Large scale growth scenarios involving specialized equipment more... (e.g. load balancers and clusters) are all but abstracted away by relying on a cloud computing platforms technology.

Structur

Elem al Elem ents

ICS In addition, several cloud computing platforms support data HTM tier technologies that L and the precedent set by Relational exceed XHT HTML Database Systems (RDBMS): Map Reduce, web service APIs, is used ML are the prog etc. Some platforms rams writ large scale RDBMS deployments. support as the grap foundation The src of all hical and Java ten attribute and the also recein JavaScri user interfac web develop desc as the e in clien ment. ive data pt. Server-s the ima alt attribute ribes whe output likew ge is describe re the ima mechan from CLOUD COMPUTING PLATFORMS AND ide languag t-side ise unavaila ge le ism. The web pag s alte Nested es like was onc use HTML ble. rnate can be emergin es and use UNDERLYING CONCEPTS and XHT PHP text that e tags found, Tags standard a very loos g Ajax HTML ML as is disp can tech ely-de thei ization, layed cannot be (and freq need ned lang r visual eng nologies if but as for overlap uen it has ine. b></ Amazon EC2: ther stanstandard software and uage with whe Industry dard , so <a>< tly are) nest become virtualization HTML a> is s has ne. b></ ed insid bec heavily based on very little more Amazons cloud computing ose the curr you cho platform isome a></ imp e b> is mor ent stan to writ not lega each othe that will industry standard software and virtualization technology. ortant, the e HTM e apparen dards HTM r. Tags l, but t. Reg L or XHT simplify will help L VS <a>< and XHT ardless XHTM b></ all you ML, ML physical r othe you prov to L Virtualization allows aare actu piece of hardware idebe understand of HTML much a solid of the ing has ally simp r web cod foundati utilized by multiple operating systems. This allows resources function job adm been arou ing. ler than Fortuna commo on nd for they (e.g. bandwidth,n elem CPU) to be mov memory, ality has allocated exclusively to expecte irably, that tely some used Every job time. d. Earl to be, HTML ent instances. ed to CSS page Brow individual operating system s While y HTM has expand because . ser (HTM common it has ed far L or XHT done web dev manufacture L had very more its extensio .) All are ML shar limit than rs add elopers As a user of Amazons EC2 cloud computing platform, you are result anybody es cert ed man ed layout n. HTM essentia came is proc lly plai supp L les assigned essor an operating system in the same wayain on all hosting as elements ort. The late a lack of stan up with clev y competi n text should ng stan st web in dar er wor not be dar kar standar cr

HTM

L BAS

RichFaces CSS3 Lucene Spring Roo


DZone, Inc. 140 Preston Executive Dr. Suite 100 Cary, NC 27513 888.678.0399 919.678.0300 $7.95 Refcardz Feedback Welcome refcardz@dzone.com Sponsorship Opportunities sales@dzone.com

DZone communities deliver over 6 million pages each month to more than 3.3 million software developers, architects and decision makers. DZone offers something for everyone, including news, tutorials, cheat sheets, blogs, feature articles, source code and more. DZone is a developers dream, says PC Magazine.
Copyright 2011 DZone, Inc. All rights reserved. No part of this publication may be reproduced, stored in a retrieval system, or transmitted, in any form or by means electronic, mechanical, photocopying, or otherwise, without prior written permission of the publisher.

Version 1.0

You might also like

pFad - Phonifier reborn

Pfad - The Proxy pFad of © 2024 Garber Painting. All rights reserved.

Note: This service is not intended for secure transactions such as banking, social media, email, or purchasing. Use at your own risk. We assume no liability whatsoever for broken pages.


Alternative Proxies:

Alternative Proxy

pFad Proxy

pFad v3 Proxy

pFad v4 Proxy