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의 동일한 렌더링을 얻을 수 있습니다.
더 나은 이해를 위해 위의 예제를 단계별 방법으로 실행하는 것이 좋습니다.