MVVM - ईवेंट

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

  • एक WPF एप्लिकेशन में जो MVVM (मॉडल-व्यू-व्यूमॉडल) डिजाइन पैटर्न का उपयोग करता है, दृश्य मॉडल वह घटक है जो एप्लिकेशन की प्रस्तुति तर्क और स्थिति को संभालने के लिए जिम्मेदार है।

  • दृश्य के कोड-पीछे फ़ाइल में किसी भी उपयोगकर्ता इंटरफ़ेस (UI) तत्व जैसे बटन या कॉम्बो बॉक्स से उठने वाली घटनाओं को संभालने के लिए कोई कोड नहीं होना चाहिए और न ही इसमें कोई डोमेन विशिष्ट तर्क होना चाहिए।

  • आदर्श रूप में, किसी व्यू के कोड-बैक में केवल एक कंस्ट्रक्टर होता है जो इनिशियलाइज़कम्पोनेंट विधि को कॉल करता है और शायद कुछ अतिरिक्त कोड को व्यू लेयर के साथ नियंत्रित या इंटरैक्ट करने के लिए जो एक्सएएमएल में व्यक्त करने के लिए मुश्किल या अक्षम है, जैसे कि जटिल एनिमेशन।

आइए हमारे एप्लिकेशन में बटन क्लिक घटनाओं के एक सरल उदाहरण पर एक नज़र डालें। निम्नलिखित MainWindow.xaml फ़ाइल का XAML कोड है जिसमें आपको दो बटन दिखाई देंगे।

<Window x:Class = "MVVMHierarchiesDemo.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:MVVMHierarchiesDemo" 
   xmlns:views = "clr-namespace:MVVMHierarchiesDemo.Views" 
   xmlns:viewModels = "clr-namespace:MVVMHierarchiesDemo.ViewModel" 
   mc:Ignorable = "d" 
   Title = "MainWindow" Height = "350" Width = "525">
	
   <Window.DataContext> 
      <local:MainWindowViewModel/> 
   </Window.DataContext>
	
   <Window.Resources> 
      <DataTemplate DataType = "{x:Type viewModels:CustomerListViewModel}">
         <views:CustomerListView/> 
      </DataTemplate>
		 
      <DataTemplate DataType = "{x:Type viewModels:OrderViewModel}">
         <views:OrderView/>
      </DataTemplate> 
   </Window.Resources> 

   <Grid> 
      <Grid.RowDefinitions> 
         <RowDefinition Height = "Auto" /> 
         <RowDefinition Height = "*" /> 
      </Grid.RowDefinitions> 
		
      <Grid x:Name = "NavBar"> 
         <Grid.ColumnDefinitions> 
            <ColumnDefinition Width = "*" />
            <ColumnDefinition Width = "*" /> 
            <ColumnDefinition Width = "*" /> 
         </Grid.ColumnDefinitions>
			
         <Button Content = "Customers" 
            Command = "{Binding NavCommand}" 
            CommandParameter = "customers" 
            Grid.Column = "0" />
				
         <Button Content = "Order" 
            Command = "{Binding NavCommand}" 
            CommandParameter = "orders" 
            Grid.Column = "2" />
      </Grid>
		
      <Grid x:Name = "MainContent" Grid.Row = "1"> 
         <ContentControl Content = "{Binding CurrentViewModel}" />
      </Grid> 
		
   </Grid> 

</Window>

आप देख सकते हैं कि उपरोक्त XAML फ़ाइल में बटन क्लिक संपत्ति का उपयोग नहीं किया गया है, लेकिन बटन दबाए जाने पर विभिन्न दृश्य लोड करने के लिए Command और CommandParameter गुण का उपयोग किया जाता है। अब आपको MainWindowViewModel.cs फ़ाइल में कमांड कार्यान्वयन को परिभाषित करने की आवश्यकता है, लेकिन व्यू फ़ाइल में नहीं। निम्नलिखित MainWindowViewModel कार्यान्वयन है।

using MVVMHierarchiesDemo.ViewModel; 
using MVVMHierarchiesDemo.Views; 

using System; 
using System.Collections.Generic; 
using System.Linq; 
using System.Text; 
using System.Threading.Tasks;

namespace MVVMHierarchiesDemo { 

   class MainWindowViewModel : BindableBase { 
	
      public MainWindowViewModel() { 
         NavCommand = new MyICommand<string>(OnNav); 
      } 

      private CustomerListViewModel custListViewModel = new CustomerListViewModel(); 
      private OrderViewModel orderViewModelModel = new OrderViewModel();

      private BindableBase _CurrentViewModel; 
		
      public BindableBase CurrentViewModel { 
         get { return _CurrentViewModel; } 
         set { SetProperty(ref _CurrentViewModel, value); } 
      } 
		
      public MyICommand<string> NavCommand { get; private set; }

      private void OnNav(string destination) { 
		
         switch (destination) { 
            case "orders": 
               CurrentViewModel = orderViewModelModel; 
               break; 
            case "customers":
               default: 
               CurrentViewModel = custListViewModel; 
               break; 
         } 
      } 
   }
}

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

जैसा कि आप देख सकते हैं, हमने अपने MainWindow पर केवल दो बटन और एक CurrentViewModel जोड़ा है। अब यदि आप किसी भी बटन पर क्लिक करते हैं तो यह उस विशेष दृश्य में नेविगेट हो जाएगा। ग्राहक बटन पर क्लिक करें और आप देखेंगे कि CustomerListView प्रदर्शित है।

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