MVVM - साक्षात्कार प्रश्न

मॉडल, व्यू, व्यूमॉडल (एमवीवीएम पैटर्न) आप सभी को निर्देशित करने, परीक्षण करने योग्य और एक्स्टेंसिबल एप्लिकेशन लिखने के लिए अपने कोड को व्यवस्थित और संरचना करने के तरीके के बारे में मार्गदर्शन करने के बारे में है।

Model - यह केवल डेटा रखता है और इसका किसी भी व्यापारिक तर्क से कोई लेना-देना नहीं है।

ViewModel - यह मॉडल और ViewModel के बीच लिंक / कनेक्शन के रूप में कार्य करता है, और सामान को सुंदर बनाता है।

View - यह केवल स्वरूपित तिथि रखता है और अनिवार्य रूप से सब कुछ मॉडल को दर्शाता है।

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

MVVM को लागू करने के लिए तीन प्रमुख चीजें हैं -

  • Maintainability
  • Testability
  • Extensibility
  • कुछ लोगों को लगता है कि साधारण यूआई के लिए, MVVM एक ओवरकिल हो सकता है।
  • इसी तरह बड़े मामलों में, ViewModel को डिजाइन करना कठिन हो सकता है।
  • जब हम जटिल डेटा बाइंडिंग करते हैं, तो डीबग करना थोड़ा मुश्किल होगा।

सामान्य तौर पर, मॉडल समझने में सबसे सरल है। यह क्लाइंट साइड डेटा मॉडल है जो एप्लिकेशन में विचारों का समर्थन करता है।

  • यह स्मृति में डेटा समाहित करने के लिए गुणों और कुछ चर के साथ वस्तुओं से बना है।

  • उन गुणों में से कुछ में अन्य मॉडल ऑब्जेक्ट्स का संदर्भ हो सकता है और ऑब्जेक्ट ग्राफ़ बना सकता है जो कि संपूर्ण मॉडल ऑब्जेक्ट्स है।

  • मॉडल ऑब्जेक्ट्स को प्रॉपर्टी चेंज नोटिफिकेशन को उठाना चाहिए जो कि WPF का मतलब डेटा बाइंडिंग है।

  • अंतिम ज़िम्मेदारी सत्यापन है जो वैकल्पिक है, लेकिन आप INOTifyDataErrorInfo / IDataErrorInfo जैसे इंटरफेस के माध्यम से WPF डेटा बाइंडिंग सत्यापन सुविधाओं का उपयोग करके मॉडल ऑब्जेक्ट पर सत्यापन जानकारी एम्बेड कर सकते हैं।

विचारों का मुख्य उद्देश्य और जिम्मेदारियों की संरचना को परिभाषित करना है कि उपयोगकर्ता स्क्रीन पर क्या देखता है। संरचना में स्थिर और गतिशील भाग होते हैं।

  • स्थिर भाग XAML पदानुक्रम है जो नियंत्रण और नियंत्रण के लेआउट को परिभाषित करता है जो एक दृश्य से बना है।

  • गतिशील हिस्सा एनिमेशन या राज्य परिवर्तनों की तरह होता है जिन्हें व्यू के हिस्से के रूप में परिभाषित किया जाता है।

  • MVVM का प्राथमिक लक्ष्य यह है कि दृश्य में पीछे कोई कोड न हो।

  • देखने के लिए आपको कम से कम कंस्ट्रक्टर और कंपोनेंट को इनिशियलाइज़ करने के लिए कॉल की आवश्यकता होगी।

  • इवेंट हैंडलिंग, एक्शन और डेटा हेरफेर लॉजिक कोड व्यू के पीछे कोड में नहीं होना चाहिए।

  • अन्य प्रकार के कोड भी हैं जिन्हें किसी भी कोड के पीछे कोड में जाना पड़ता है जो कि UI तत्व का संदर्भ होना आवश्यक है। यह स्वाभाविक रूप से कोड देखें।

  • ViewModel MVVM एप्लिकेशन का मुख्य बिंदु है। ViewModel की प्राथमिक जिम्मेदारी दृश्य को डेटा प्रदान करना है, ताकि दृश्य उस डेटा को स्क्रीन पर रख सके।

  • यह उपयोगकर्ता को डेटा के साथ बातचीत करने और डेटा को बदलने की अनुमति भी देता है।

  • ViewModel की अन्य महत्वपूर्ण जिम्मेदारी एक दृश्य के लिए इंटरैक्शन लॉजिक को एनक्रिप्ट करना है, लेकिन इसका मतलब यह नहीं है कि एप्लिकेशन के सभी लॉजिक ViewModel में जाने चाहिए।

  • यह उपयोगकर्ता या दृश्य पर किसी भी परिवर्तन के आधार पर सही चीज़ बनाने के लिए कॉल की उपयुक्त अनुक्रमण को संभालने में सक्षम होना चाहिए।

  • ViewModel को किसी भी नेविगेशन लॉजिक को भी प्रबंधित करना चाहिए जैसे निर्णय लेने का समय जब किसी अलग दृश्य में नेविगेट करने का समय हो।

विचारों के निर्माण के दो तरीके हैं। आप उनमें से किसी एक का उपयोग कर सकते हैं।

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

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

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

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

आमतौर पर, 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 के बजाय कोड-पीछे में ViewModel के निर्माण का मुख्य कारण यह है कि व्यू मॉडल कंस्ट्रक्टर पैरामीटर लेता है, लेकिन डिफ़ॉल्ट निर्माण में परिभाषित होने पर XAML पार्सिंग केवल तत्वों का निर्माण कर सकता है।

ViewModelLocator पहले निर्माण को देखने के लिए एक मानक, सुसंगत, घोषणात्मक और शिथिल युग्मित तरीका प्रदान करता है जो ViewModel को देखने के लिए झुका हुआ होने की प्रक्रिया को स्वचालित करता है। निम्नलिखित ViewModelLocator की उच्च स्तरीय प्रक्रिया है।

  • चित्र देखें कि किस प्रकार का निर्माण किया जा रहा है।
  • उस विशेष दृश्य प्रकार के लिए ViewModel को पहचानें।
  • उस ViewModel का निर्माण करें।
  • ViewModel के लिए दृश्य DataContext सेट करें।

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

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

डेटा बाइंडिंग का उपयोग करने वाले तत्व के लिए मौजूदा डेटा टेम्पलेट स्वचालित रूप से वर्तमान संसाधन शब्दकोश से एक उपयुक्त टेम्पलेट का चयन कर सकते हैं। वे ऐसा डेटा ऑब्जेक्ट के प्रकार के आधार पर करते हैं जो डेटा बाइंडिंग द्वारा प्रदान किया जाता है। सबसे पहले आपके पास कुछ तत्व होना चाहिए जो डेटा ऑब्जेक्ट के लिए बाध्य हो।

कमांड पैटर्न में दो मुख्य कलाकार, इनवॉकर और रिसीवर हैं।

Invoker

इनवॉकर कोड का एक टुकड़ा है जो कुछ अनिवार्य तर्क को निष्पादित कर सकता है। आमतौर पर, यह एक यूआई तत्व है जिसे उपयोगकर्ता एक यूआई फ्रेमवर्क के संदर्भ में बातचीत करता है। लेकिन यह आवेदन में कहीं और तर्क कोड का एक और हिस्सा हो सकता है।

Receiver

रिसीवर तर्क है कि निष्पादन के लिए अभिप्रेत है जब हमलावर फायर करता है। MVVM के संदर्भ में, रिसीवर आमतौर पर आपके ViewModel में एक विधि है जिसे कॉल करने की आवश्यकता होती है।

इनवॉकर और रिसीवर के बीच में आपके पास एक अवरोधक परत होती है जो इनवोक और रिसीवर को एक दूसरे के बारे में स्पष्ट रूप से जानने की अनुमति नहीं देती है। यह आमतौर पर एक इंटरफेस के रूप में निरूपित किया जाता है जो कि इनवोकर के संपर्क में आता है और उस इंटरफ़ेस का एक ठोस कार्यान्वयन रिसीवर को कॉल करने में सक्षम होता है।

नहीं, यदि सामग्री का हिस्सा केवल स्क्रीन को कुछ प्रदान करने के लिए संरचना प्रदान करता है और उस सामग्री के लिए उपयोगकर्ता द्वारा किसी भी इनपुट या हेरफेर का समर्थन नहीं करता है। यह एक अलग ViewModel की आवश्यकता नहीं हो सकती है, लेकिन यह सिर्फ एक XAML हो सकता है जो माता-पिता ViewModel द्वारा उजागर गुणों के आधार पर प्रस्तुत करता है।

जब आपका एप्लिकेशन अंतिम उपयोगकर्ताओं से डेटा इनपुट स्वीकार करना शुरू करता है, तो आपको उस इनपुट को मान्य करने पर विचार करना होगा। यह सुनिश्चित करने के लिए कि यह आपकी समग्र आवश्यकताओं के अनुरूप है।

आप WPF डेटा बाइंडिंग द्वारा समर्थित सत्यापन को व्यक्त करने के निम्नलिखित तरीकों का उपयोग कर सकते हैं -

  • एक संपत्ति पर अपवादों को फेंकना निर्धारित है।
  • IDataErrorInfo इंटरफ़ेस को लागू करना।
  • INotifyDataErrorInfo को लागू करना।
  • WPF सत्यापन नियमों का उपयोग करें।

इनवर्टर ऑफ कंट्रोल (IoC) और निर्भरता इंजेक्शन दो डिज़ाइन पैटर्न हैं जो निकट से संबंधित हैं और कंटेनर मूल रूप से इन्फ्रास्ट्रक्चर कोड का एक हिस्सा है जो आपके लिए इन दोनों पैटर्न को करता है। IoC पैटर्न निर्माण के लिए जिम्मेदारी सौंपने के बारे में है और निर्भरता इंजेक्शन पैटर्न उस वस्तु पर निर्भरता प्रदान करने के बारे में है जो पहले से ही निर्माण की गई है।

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