MVVM – WPF 데이터 템플릿

템플릿은 컨트롤의 전체적인 모양과 시각적 모양을 설명합니다. 각 컨트롤에 대해 해당 컨트롤에 모양을 제공하는 연결된 기본 템플릿이 있습니다. WPF 응용 프로그램에서 컨트롤의 시각적 동작과 시각적 모양을 사용자 지정하려는 경우 고유 한 템플릿을 쉽게 만들 수 있습니다. 논리와 템플릿 간의 연결은 데이터 바인딩을 통해 얻을 수 있습니다.

MVVM에는 ViewModel 첫 번째 구성으로 알려진 또 다른 기본 양식이 있습니다.

  • ViewModel의 첫 번째 생성 접근 방식은 WPF의 암시 적 데이터 템플릿 기능을 활용합니다.

  • 암시 적 데이터 템플릿은 데이터 바인딩을 사용하는 요소에 대해 현재 리소스 사전에서 적절한 템플릿을 자동으로 선택할 수 있습니다. 데이터 바인딩에 의해 렌더링되는 데이터 개체의 유형에 따라이를 수행합니다. 첫째, 데이터 개체에 바인딩되는 요소가 있어야합니다.

먼저 데이터 템플릿, 특히 암시 적 데이터 템플릿을 활용하여 뷰 모델을 수행하는 방법을 이해하는 간단한 예제를 다시 살펴 보겠습니다. 다음은 StudentViewModel 클래스의 구현입니다.

using MVVMDemo.Model; 
using System.Collections.ObjectModel;

namespace MVVMDemo.ViewModel { 

   public class StudentViewModel {
	
      public StudentViewModel() { 
         LoadStudents(); 
      } 
		
      public ObservableCollection<Student> Students { 
         get; 
         set; 
      }
		
      public void LoadStudents() { 
         ObservableCollection<Student> students = new ObservableCollection<Student>();
			
         students.Add(new Student { FirstName = "Mark", LastName = "Allain" }); 
         students.Add(new Student { FirstName = "Allen", LastName = "Brown" }); 
         students.Add(new Student { FirstName = "Linda", LastName = "Hamerski" }); 
			
         Students = students; 
      } 
   } 
}

위의 ViewModel이 변경되지 않았 음을 알 수 있습니다. 이전 장과 동일한 예제를 계속 진행합니다. 이 ViewModel 클래스는 Students 컬렉션 속성을 노출하고 생성시 채 웁니다. StudentView.xaml 파일로 이동하여 기존 구현을 제거하고 Resources 섹션에서 데이터 템플릿을 정의하겠습니다.

<UserControl.Resources> 
   <DataTemplate x:Key = "studentsTemplate">
	
      <StackPanel Orientation = "Horizontal"> 
         <TextBox Text = "{Binding Path = FirstName, Mode = TwoWay}" 
            Width = "100" Margin = "3 5 3 5"/> 
				
         <TextBox Text = "{Binding Path = LastName, Mode = TwoWay}" 
            Width = "100" Margin = "0 5 3 5"/> 
				
         <TextBlock Text = "{Binding Path = FullName, Mode = OneWay}" 
            Margin = "0 5 3 5"/> 
      </StackPanel> 
		
   </DataTemplate> 
</UserControl.Resources>

이제 다음 코드와 같이 목록 상자를 추가하고 해당 목록 상자를 Students 속성에 데이터 바인딩합니다.

<ListBox ItemsSource = "{Binding Students}" ItemTemplate = "{StaticResource studentsTemplate}"/>

리소스 섹션에서 DataTemplate에는 studentsTemplate의 키가 있으며 실제로 해당 템플릿을 사용하려면 ListBox의 ItemTemplate 속성을 사용해야합니다. 이제 목록 상자에 해당 학생을 렌더링하기 위해 특정 템플릿을 사용하도록 지시하는 것을 볼 수 있습니다. 다음은 StudentView.xaml 파일의 전체 구현입니다.

<UserControl x:Class = "MVVMDemo.Views.StudentView" 
   xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation" 
   xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml" 
   xmlns:mc = "http://schemas.openxmlformats.org/markup-compatibility/2006"
   xmlns:d = "http://schemas.microsoft.com/expression/blend/2008" 
   xmlns:local = "clr-namespace:MVVMDemo.Views" 
   xmlns:viewModel = "clr-namespace:MVVMDemo.ViewModel" 
   xmlns:vml = "clr-namespace:MVVMDemo.VML" 
   vml:ViewModelLocator.AutoHookedUpViewModel = "True" 
   mc:Ignorable = "d" d:DesignHeight = "300" d:DesignWidth = "300">
	
   <UserControl.Resources> 
      <DataTemplate x:Key = "studentsTemplate"> 
		
         <StackPanel Orientation = "Horizontal"> 
            <TextBox Text = "{Binding Path = FirstName, Mode = TwoWay}" 
               Width = "100" Margin = "3 5 3 5"/> 
					
            <TextBox Text = "{Binding Path = LastName, Mode = TwoWay}" 
               Width = "100" Margin = "0 5 3 5"/> 
					
            <TextBlock Text = "{Binding Path = FullName, Mode = OneWay}" 
               Margin = "0 5 3 5"/> 
					
         </StackPanel> 
			
      </DataTemplate> 
   </UserControl.Resources>
	
   <Grid> 
      <ListBox 
         ItemsSource = "{Binding Students}" 
         ItemTemplate = "{StaticResource studentsTemplate}"/> 
   </Grid>
	
</UserControl>

위의 코드를 컴파일하고 실행하면 ListBox 하나가 포함 된 다음과 같은 창이 나타납니다. 각 ListBoxItem에는 TextBlock 및 텍스트 상자에 표시되는 Student 클래스 개체 데이터가 포함되어 있습니다.

이를 암시 적 템플릿으로 만들려면 목록 상자에서 ItemTemplate 속성을 제거하고 다음 코드와 같이 템플릿 정의에 DataType 속성을 추가해야합니다.

<UserControl.Resources> 
   <DataTemplate DataType = "{x:Type data:Student}">
	
      <StackPanel Orientation = "Horizontal"> 
         <TextBox Text = "{Binding Path = FirstName, Mode = TwoWay}" 
            Width = "100" Margin = "3 5 3 5"/> 
				
         <TextBox Text = "{Binding Path = LastName, Mode = TwoWay}" 
            Width = "100" Margin = "0 5 3 5"/> 
				
         <TextBlock Text = "{Binding Path = FullName, Mode = OneWay}" 
            Margin = "0 5 3 5"/> 
				
      </StackPanel> 
		
   </DataTemplate> 
</UserControl.Resources>
 
<Grid> 
   <ListBox ItemsSource = "{Binding Students}"/> 
</Grid>

DataTemplate에서 x : Type 태그 확장은 XAML의 연산자 유형과 마찬가지로 매우 중요합니다. 따라서 기본적으로 MVVMDemo.Model 네임 스페이스에있는 Student 데이터 유형을 가리켜 야합니다. 다음은 업데이트 된 완전한 XAML 파일입니다.

<UserControl x:Class="MVVMDemo.Views.StudentView" 
   xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation" 
   xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml" 
   xmlns:mc = "http://schemas.openxmlformats.org/markup-compatibility/2006" 
   xmlns:d = "http://schemas.microsoft.com/expression/blend/2008" 
   xmlns:local = "clr-namespace:MVVMDemo.Views" 
   xmlns:viewModel = "clr-namespace:MVVMDemo.ViewModel" 
   xmlns:data = "clr-namespace:MVVMDemo.Model" 
   xmlns:vml = "clr-namespace:MVVMDemo.VML" 
   vml:ViewModelLocator.AutoHookedUpViewModel = "True" 
   mc:Ignorable = "d" d:DesignHeight = "300" d:DesignWidth = "300">
	
   <UserControl.Resources> 
      <DataTemplate DataType = "{x:Type data:Student}"> 
		
         <StackPanel Orientation = "Horizontal"> 
            <TextBox Text = "{Binding Path = FirstName, Mode = TwoWay}" 
               Width = "100" Margin = "3 5 3 5"/> 
					
            <TextBox Text = "{Binding Path = LastName, Mode = TwoWay}" 
               Width = "100" Margin = "0 5 3 5"/> 
					
            <TextBlock Text = "{Binding Path = FullName, Mode = OneWay}" 
               Margin = "0 5 3 5"/> 
					
         </StackPanel> 
			
      </DataTemplate> 
   </UserControl.Resources>
	
   <Grid>
      <ListBox ItemsSource = "{Binding Students}"/> 
   </Grid> 
	
</UserControl>

이 응용 프로그램을 다시 실행하면 적절한 DataTemplate을 찾아서 렌더링되는 개체의 유형을 자동으로 매핑하므로 데이터 템플릿이있는 Students의 동일한 렌더링을 얻을 수 있습니다.

더 나은 이해를 위해 위의 예제를 단계별 방법으로 실행하는 것이 좋습니다.