एमवीवीएम - हुकिंग अप व्यूज

इस अध्याय में, हम विभिन्न तरीकों को शामिल करेंगे जिसमें आप अपने विचारों को व्यूमॉडल तक पहुंचा सकते हैं। पहले, आइए देखें पहले निर्माण पर एक नजर डालें जहां हम इसे XAML में घोषित कर सकते हैं। जैसा कि हमने पिछले अध्याय में उदाहरण देखा है जहां हमने मुख्य विंडो से एक दृश्य को देखा है। अब हम विचारों को हुक करने के अन्य तरीके देखेंगे।

हम इस अध्याय में भी उसी उदाहरण का उपयोग करेंगे। निम्नलिखित समान मॉडल वर्ग कार्यान्वयन है।

using System.ComponentModel;

namespace MVVMDemo.Model {
 
   public class StudentModel {} 
	
   public class Student : INotifyPropertyChanged { 
      private string firstName; 
      private string lastName;
		
      public string FirstName { 
         get { return firstName; }
			
         set { 
            if (firstName != value) { 
               firstName = value; 
               RaisePropertyChanged("FirstName");
               RaisePropertyChanged("FullName"); 
            } 
         } 
      }
	
      public string LastName {
         get { return lastName; } 
			
         set { 
            if (lastName != value) { 
               lastName = value; 
               RaisePropertyChanged("LastName");
               RaisePropertyChanged("FullName"); 
            } 
         } 
      }
	
      public string FullName { 
         get { 
            return firstName + " " + lastName; 
         } 
      }
	
      public event PropertyChangedEventHandler PropertyChanged;
	
      private void RaisePropertyChanged(string property) { 
         if (PropertyChanged != null) { 
            PropertyChanged(this, new PropertyChangedEventArgs(property)); 
         } 
      } 
   }  
}

यहाँ ViewModel वर्ग कार्यान्वयन है। इस बार लोडस्ट्रूडेंट्स विधि को डिफॉल्ट कंस्ट्रक्टर में कहा जाता है।

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; 
      } 
   } 
}

चाहे दृश्य एक विंडो, उपयोगकर्ता नियंत्रण या पृष्ठ है, पार्सर आम तौर पर ऊपर से नीचे और बाएं से दाएं काम करता है। यह प्रत्येक तत्व के लिए डिफॉल्ट कंस्ट्रक्टर को कॉल करता है क्योंकि यह उसका सामना करता है। दृश्य बनाने के दो तरीके हैं। आप उन पर किसी का उपयोग कर सकते हैं।

  • XAML में पहला निर्माण देखें
  • कोड-पीछे में पहला निर्माण देखें

XAML में पहला निर्माण देखें

एक तरीका यह है कि डेटाकोटेक्स्ट संपत्ति के लिए सेटर में एक नेस्टेड तत्व के रूप में अपने ViewModel को निम्न कोड में दिखाया गया है।

<UserControl.DataContext> 
   <viewModel:StudentViewModel/> 
</UserControl.DataContext>

यहाँ पूरा 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"
   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>

कोड-पीछे में पहला निर्माण देखें

दूसरा तरीका यह है कि आप व्यू फर्स्ट कंस्ट्रक्शन प्राप्त कर सकते हैं, उदाहरण के साथ डेटाकोटेक्स्ट प्रॉपर्टी को सेट करके अपने व्यू के पीछे कोड में बस व्यू मॉडल का निर्माण कर सकते हैं।

आमतौर पर, DataContext प्रॉपर्टी को देखने की विधायक विधि में सेट किया जाता है, लेकिन आप निर्माण को तब तक के लिए स्थगित कर सकते हैं जब तक कि व्यू की लोड घटना आग नहीं बन जाती।

using System.Windows.Controls;

namespace MVVMDemo.Views {
 
   /// <summary> 
      /// Interaction logic for StudentView.xaml 
   /// </summary> 
	
   public partial class StudentView : UserControl { 
      public StudentView() { 
         InitializeComponent(); 
         this.DataContext = new MVVMDemo.ViewModel.StudentViewModel(); 
      } 
   } 
}

XAML के बजाय कोड-पीछे में व्यू मॉडल के निर्माण का एक कारण यह है कि व्यू मॉडल कंस्ट्रक्टर पैरामीटर लेता है, लेकिन XAML पार्सिंग केवल तत्वों का निर्माण कर सकता है यदि डिफ़ॉल्ट कंस्ट्रक्टर में परिभाषित किया गया है।

अब इस स्थिति में 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" 
   mc:Ignorable = "d" 
   d:DesignHeight = "300" 
   d:DesignWidth = "300">
	
   <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>

आप इस दृश्य को मेनविन्डो में घोषित कर सकते हैं जैसा कि मेनविन्डो.एक्सएएमएल फाइल में दिखाया गया है।

<Window x:Class = "MVVMDemo.MainWindow" 
   xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation" 
   xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
   xmlns:d = "http://schemas.microsoft.com/expression/blend/2008" 
   xmlns:mc = "http://schemas.openxmlformats.org/markup-compatibility/2006" 
   xmlns:local = "clr-namespace:MVVMDemo" 
   xmlns:views = "clr-namespace:MVVMDemo.Views" 
   mc:Ignorable = "d" 
   Title = "MainWindow" Height = "350" Width = "525"> 
	
   <Grid> 
      <views:StudentView x:Name = "StudentViewControl"/> 
   </Grid> 
	
</Window>

जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आप अपनी मुख्य विंडो पर निम्न आउटपुट देखेंगे।

हम आपको बेहतर समझ के लिए चरण-दर-चरण तरीके से उपरोक्त उदाहरण को निष्पादित करने की सलाह देते हैं।