MVVM - WPF डेटा बाइंडिंग

इस अध्याय में, हमें पता चलेगा कि डेटा बाइंडिंग MVVM पैटर्न का समर्थन कैसे करती है। डेटा बाइंडिंग प्रमुख विशेषता है जो एमवी और एमवीपी जैसे अन्य यूआई सेपरेटिंग पैटर्न से एमवीवीएम को अलग करती है।

  • डेटा बाइंडिंग के लिए आपके पास निर्मित UI तत्वों का एक दृश्य या सेट होना आवश्यक है, और फिर आपको कुछ अन्य ऑब्जेक्ट की आवश्यकता होती है जो बाइंडिंग इंगित करने वाले हैं।

  • एक दृश्य में UI तत्व गुण के लिए बाध्य होते हैं जो ViewModel द्वारा उजागर होते हैं।

  • दृश्य और दृश्यमॉडल का निर्माण जिस क्रम पर किया गया है, वह उस स्थिति पर निर्भर करता है, जैसा कि हमने पहले दृश्य को कवर किया है।

  • एक दृश्य और ViewModel का निर्माण हो जाता है और ViewCodtext का दृश्य ViewModel पर सेट हो जाता है।

  • बाइंडिंग या तो व्यू और व्यूमॉडल के बीच डेटा को आगे और पीछे प्रवाहित करने के लिए OneWay या TwoWay डेटा बाइंडिंग हो सकते हैं।

आइए एक ही उदाहरण में डेटा बाइंडिंग पर एक नज़र डालें। नीचे स्टूडेंट व्यू का 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 कोड को देखते हैं तो आप देखेंगे कि ItemControl ViewModel द्वारा उजागर किए गए छात्रों के संग्रह के लिए बाध्य है।

  • आप यह भी देख सकते हैं कि छात्र मॉडल की संपत्ति के साथ-साथ उनके अपने व्यक्तिगत बाइंडिंग भी हैं, और ये टेक्स्टबॉक्स और टेक्स्टलॉक के लिए बाध्य हैं।

  • ItemControl का ItemSource छात्रों की संपत्ति के लिए बाध्य करने में सक्षम है, क्योंकि व्यू के लिए समग्र DataContext ViewModel पर सेट है।

  • यहाँ संपत्तियों के अलग-अलग बाइंडिंग भी DataContext बाइंडिंग हैं, लेकिन वे ViewModel के खिलाफ बाध्यकारी नहीं हैं, क्योंकि जिस तरह से एक आइटम स्रोत काम करता है।

  • जब कोई आइटम स्रोत अपने संग्रह से जुड़ जाता है, तो वह रेंडरिंग के दौरान प्रत्येक आइटम के लिए एक कंटेनर प्रदान करता है, और यह उस कंटेनर के DataContext को आइटम पर सेट करता है। तो एक पंक्ति के भीतर प्रत्येक टेक्स्टबॉक्स और टेक्स्टब्लॉक के लिए समग्र डेटा कॉन्टेक्स्ट संग्रह में एक व्यक्तिगत छात्र होने जा रहा है। और आप यह भी देख सकते हैं कि TextBoxes के लिए ये बाइंडिंग TwoWay डेटा बाइंडिंग है और TextBlock के लिए यह OneWay डेटा बाइंडिंग है क्योंकि आप TextBlock को संपादित नहीं कर सकते।

जब आप इस एप्लिकेशन को फिर से चलाते हैं, तो आपको निम्न आउटपुट दिखाई देगा।

आइए अब एलन को अपस्टोन से पहली पंक्ति के दूसरे टेक्स्टबॉक्स में टेक्स्ट बदलें और फोकस खोने के लिए टैब दबाएं। आप देखेंगे कि टेक्स्टब्लॉक टेक्स्ट भी अपडेट किया गया है।

ऐसा इसलिए है क्योंकि TextBox के बाइंडिंग TwoWay पर सेट हैं और यह मॉडल को भी अपडेट करता है, और मॉडल से फिर से TextBlock अपडेट किया जाता है।