MVVM - परिचय
अपने कोड को व्यवस्थित करने के लिए सुव्यवस्थित और संभवतः सबसे पुन: प्रयोज्य तरीका 'MVVM' पैटर्न का उपयोग करना है। Model, View, ViewModel (MVVM pattern) आप सभी को निर्देशित करने योग्य, परीक्षण योग्य और एक्स्टेंसिबल एप्लिकेशन लिखने के लिए अपने कोड को व्यवस्थित और संरचना करने के तरीके में मार्गदर्शन करने के बारे में है।
Model - यह केवल डेटा रखता है और इसका किसी भी व्यापारिक तर्क से कोई लेना-देना नहीं है।
ViewModel - यह मॉडल और दृश्य के बीच लिंक / कनेक्शन के रूप में कार्य करता है और सामान को सुंदर बनाता है।
View - यह केवल स्वरूपित डेटा रखता है और अनिवार्य रूप से मॉडल के लिए सब कुछ दर्शाता है।
अलग से प्रस्तुतिकरण
कोड-पीछे या XAML में एप्लिकेशन लॉजिक लगाने से होने वाली समस्याओं से बचने के लिए, अलग-अलग प्रस्तुति के रूप में ज्ञात तकनीक का उपयोग करना सबसे अच्छा है। हम इससे बचने की कोशिश कर रहे हैं, जहां हमारे पास एक्सएएमएल और कोड-पीछे होगा जिसमें उपयोगकर्ता इंटरफ़ेस ऑब्जेक्ट्स के साथ सीधे काम करने के लिए न्यूनतम आवश्यक है। उपयोगकर्ता इंटरफ़ेस कक्षाओं में जटिल इंटरैक्शन व्यवहार, एप्लिकेशन लॉजिक और बाकी सब के लिए कोड भी होता है जैसा कि बाईं ओर निम्नलिखित आकृति में दिखाया गया है।
अलग प्रस्तुति के साथ, उपयोगकर्ता इंटरफ़ेस वर्ग बहुत सरल है। इसमें XAML जरूर है, लेकिन पीछे वाला कोड उतना ही व्यावहारिक है।
एप्लिकेशन तर्क एक अलग वर्ग में है, जिसे अक्सर मॉडल के रूप में संदर्भित किया जाता है।
हालांकि, यह पूरी कहानी नहीं है। यदि आप यहां रुकते हैं, तो आप एक बहुत ही सामान्य गलती को दोहराने की संभावना रखते हैं जो आपको डेटा बाइंडिंग पागलपन का रास्ता दिखाएगा।
कई डेवलपर्स XAML में तत्वों को सीधे मॉडल में गुणों से जोड़ने के लिए डेटा बाइंडिंग का उपयोग करने का प्रयास करते हैं।
अब कभी-कभी यह ठीक हो सकता है, लेकिन अक्सर यह नहीं है। समस्या यह है कि मॉडल पूरी तरह से इस बात से संबंधित है कि एप्लिकेशन क्या करता है, और यह नहीं कि उपयोगकर्ता एप्लिकेशन के साथ कैसे इंटरैक्ट करता है।
जिस तरह से आप डेटा प्रस्तुत करते हैं वह अक्सर आंतरिक रूप से कैसे संरचित होता है, से कुछ हद तक अलग होता है।
इसके अलावा, अधिकांश उपयोगकर्ता इंटरफ़ेस में कुछ स्थिति होती है जो एप्लिकेशन मॉडल में नहीं होती है।
उदाहरण के लिए, यदि आपका उपयोगकर्ता इंटरफ़ेस एक ड्रैग एंड ड्रॉप का उपयोग करता है, तो कुछ चीजों पर नज़र रखने की ज़रूरत है, जैसे कि आइटम को कहाँ खींचा जा रहा है, अभी ठीक है, इसकी उपस्थिति कैसे बदलनी चाहिए क्योंकि यह संभावित ड्रॉप लक्ष्य से आगे बढ़ता है, और उन ड्रॉप लक्ष्य भी कैसे हो सकते हैं आइटम के रूप में परिवर्तन उनके ऊपर खींच लिया जाता है।
इस तरह की स्थिति आश्चर्यजनक रूप से जटिल हो सकती है, और इसे पूरी तरह से जांचने की आवश्यकता है।
व्यवहार में, आप सामान्य रूप से उपयोगकर्ता इंटरफ़ेस और मॉडल के बीच बैठे कुछ अन्य वर्ग चाहते हैं। इसकी दो महत्वपूर्ण भूमिकाएँ हैं।
सबसे पहले, यह एक विशेष यूजर इंटरफेस दृश्य के लिए आपके एप्लिकेशन मॉडल को एडाप्ट करता है।
दूसरा, यह वह जगह है जहाँ कोई भी नॉनवेज इंटरेक्शन लॉजिक रहता है, और इसके द्वारा, मुझे मतलब है कि आपके उपयोगकर्ता इंटरफ़ेस को आपके इच्छित तरीके से व्यवहार करने के लिए कोड की आवश्यकता है।