Click here to Skip to main content
Click here to Skip to main content

MVVM Friendly DataTemplate switching

, 29 Jul 2013
Rate this:
Please Sign up or sign in to vote.
Switching data templates entirely in XAML.
I frequently have a need to switch templates inside listviews. Now, while you could create your own ItemTemplateSelector to choose templates, this just smacks to me of having to add more code to your application than really should be necessary. It would be great if you could do this entirely in XAML.
 
Well, thanks to the great Dr WPF for suggesting it, there is and it's a really simple trick. What you need to do is have your DataTemplate just wrap a Control, and swap in ControlTemplates as necessary.
<DataTemplate x:Key="MyItemTemplate">
  <Control x:Name="myControl" Template="{StaticResource MyMainTemplate}" />
  <DataTemplate.Triggers>
    <DataTrigger Binding="{Binding IsActive}" Value="True">
      <Setter TargetName="myControl" Property="Template" Value="{StaticResource MyOtherTemplate}" />
    </DataTrigger>
  </DataTemplate.Triggers>
</DataTemplate>
Now all you need do is add the templates as ControlTemplates instead of DataTemplates and point your listview at this DataTemplate.
 
As you can see, the coding is all done in your XAML and, through the judicious use of data triggers, you can have swappable templates. You've gotta love it.

License

This article, along with any associated source code and files, is licensed under The Code Project Open License (CPOL)

About the Author

Pete O'Hanlon
CEO
United Kingdom United Kingdom
A developer for over 30 years, I've been lucky enough to write articles and applications for Code Project as well as the Intel Ultimate Coder - Going Perceptual challenge. I live in the North East of England with 2 wonderful daughters and a wonderful wife.
 
I am not the Stig, but I do wish I had Lotus Tuned Suspension.
Follow on   Twitter   Google+

Comments and Discussions

 
QuestionThanks a lot for this example - I found two typos PinmemberRufus Buschart6-Jan-13 6:50 
AnswerRe: Thanks a lot for this example - I found two typos PinprotectorPete O'Hanlon29-Jul-13 6:16 
GeneralReason for my vote of 5 cool PinmemberDaniel Vaughan20-Jun-11 11:21 
GeneralRe: I like it mate. The thing I love about XAML is that there ar... PinprotectorPete O'Hanlon23-Jun-11 7:36 
GeneralReason for my vote of 5 nice PinmemberMonjurul Habib14-Jun-11 11:13 

General General    News News    Suggestion Suggestion    Question Question    Bug Bug    Answer Answer    Joke Joke    Rant Rant    Admin Admin   

Use Ctrl+Left/Right to switch messages, Ctrl+Up/Down to switch threads, Ctrl+Shift+Left/Right to switch pages.

| Advertise | Privacy | Mobile
Web01 | 2.8.140709.1 | Last Updated 29 Jul 2013
Article Copyright 2011 by Pete O'Hanlon
Everything else Copyright © CodeProject, 1999-2014
Terms of Service
Layout: fixed | fluid