MVVM – WPF 데이터 바인딩

이 장에서는 데이터 바인딩이 MVVM 패턴을 지원하는 방법에 대해 알아 봅니다. 데이터 바인딩은 MVVM을 MVC 및 MVP와 같은 다른 UI 분리 패턴과 차별화하는 핵심 기능입니다.

  • 데이터 바인딩의 경우 뷰 또는 UI 요소 집합이 생성되어야하며 바인딩이 가리킬 다른 개체가 필요합니다.

  • 뷰의 UI 요소는 ViewModel에 의해 노출되는 속성에 바인딩됩니다.

  • View와 ViewModel이 구성되는 순서는 먼저 View를 다루었으므로 상황에 따라 다릅니다.

  • View와 ViewModel이 생성되고 View의 DataContext가 ViewModel로 설정됩니다.

  • 바인딩은 OneWay 또는 TwoWay 데이터 바인딩이 될 수 있으며 View와 ViewModel간에 데이터를주고받을 수 있습니다.

동일한 예제에서 데이터 바인딩을 살펴 보겠습니다. 다음은 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.DataContext> 
      <viewModel:StudentViewModel/> 
   </UserControl.DataContext>--> 

   <Grid> 
      <StackPanel HorizontalAlignment = "Left"> 
         <ItemsControl ItemsSource = "{Binding Path = Students}"> 
            <ItemsControl.ItemTemplate>
               <DataTemplate> 
					
                  <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> 
            </ItemsControl.ItemTemplate> 
         </ItemsControl> 
      </StackPanel> 
   </Grid> 

</UserControl>
  • 위의 XAML 코드를 보면 ItemsControl이 ViewModel에 의해 노출 된 Students 컬렉션에 바인딩되어 있음을 알 수 있습니다.

  • 또한 Student 모델의 속성에 고유 한 개별 바인딩이 있으며 이러한 바인딩이 Textbox 및 TextBlock에 바인딩되어 있음을 알 수 있습니다.

  • View에 대한 전체 DataContext가 ViewModel로 설정되어 있기 때문에 ItemsControl의 ItemSource는 Students 속성에 바인딩 할 수 있습니다.

  • 여기에있는 속성의 개별 바인딩도 DataContext 바인딩이지만 ItemSource가 작동하는 방식 때문에 ViewModel 자체에 바인딩되지 않습니다.

  • 항목 소스가 컬렉션에 바인딩되면 렌더링시 각 항목에 대한 컨테이너를 렌더링하고 해당 컨테이너의 DataContext를 항목에 설정합니다. 따라서 행 내의 각 텍스트 상자 및 텍스트 블록에 대한 전체 DataContext는 컬렉션의 개별 Student가 될 것입니다. 또한 TextBox에 대한 이러한 바인딩은 TwoWay 데이터 바인딩이고 TextBlock의 경우 TextBlock을 편집 할 수 없기 때문에 OneWay 데이터 바인딩임을 알 수 있습니다.

이 애플리케이션을 다시 실행하면 다음과 같은 출력이 표시됩니다.

이제 첫 번째 행의 두 번째 텍스트 상자에있는 텍스트를 Allain에서 Upston으로 변경하고 Tab 키를 눌러 초점을 잃도록하겠습니다. TextBlock 텍스트도 업데이트되는 것을 볼 수 있습니다.

이는 TextBox의 바인딩이 TwoWay로 설정되고 모델도 업데이트되고 모델에서 다시 TextBlock이 업데이트되기 때문입니다.