MVVM - लाभ

एमवीवीएम पैटर्न अंततः एमवीसी पैटर्न की आधुनिक संरचना है, इसलिए मुख्य तर्क अभी भी डोमेन तर्क और प्रस्तुति परत के बीच स्पष्ट अलगाव प्रदान करने के लिए समान है। यहाँ MVVM पैटर्न के कुछ फायदे और नुकसान हैं।

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

तीन महत्वपूर्ण महत्वपूर्ण चीजें हैं जो एमवीवीएम को लागू करने से बाहर निकलती हैं जो निम्नानुसार हैं।

रख-रखाव

  • विभिन्न प्रकार के कोड के एक साफ जुदाई को उन अधिक दानेदार और केंद्रित भागों में से एक या कई में जाना आसान बनाना चाहिए और चिंता किए बिना परिवर्तन करना चाहिए।

  • इसका मतलब है कि आप फुर्तीले बने रह सकते हैं और नई रिलीज के लिए तेजी से आगे बढ़ सकते हैं।

testability

  • MVVM के साथ कोड का प्रत्येक टुकड़ा अधिक बारीक होता है और यदि इसे सही से लागू किया जाता है तो आपके बाहरी और आंतरिक निर्भरता कोड के अलग-अलग टुकड़ों में कोर लॉजिक के साथ भागों से होते हैं जिन्हें आप परीक्षण करना चाहते हैं।

  • इससे कोर लॉजिक के खिलाफ यूनिट टेस्ट लिखना काफी आसान हो जाता है।

  • सुनिश्चित करें कि यह सही लिखा गया काम करता है और जब चीजें रखरखाव में बदलती हैं तब भी काम करती रहती हैं।

तानाना

  • यह कभी-कभी रखरखाव के साथ ओवरलैप हो जाता है, क्योंकि साफ पृथक्करण सीमाओं और कोड के अधिक दानेदार टुकड़ों के कारण।

  • आपके पास उन भागों में से किसी को पुन: प्रयोज्य बनाने का एक बेहतर मौका है।

  • इसमें कोड के नए टुकड़ों को बदलने या जोड़ने की क्षमता भी है जो वास्तुकला में सही स्थानों पर समान चीजों को करते हैं।

एमवीवीएम पैटर्न का स्पष्ट उद्देश्य दृश्य का अमूर्त है जो कोड-पीछे में व्यापार तर्क की मात्रा को कम करता है। हालांकि, निम्नलिखित कुछ अन्य ठोस लाभ हैं -

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

नुकसान

  • कुछ लोग सोचते हैं कि सरल UI के लिए, MVVM ओवरकिल हो सकता है।
  • इसी तरह बड़े मामलों में, ViewModel को डिजाइन करना कठिन हो सकता है।
  • जब हम जटिल डेटा बाइंडिंग करते हैं, तो डीबग करना थोड़ा मुश्किल होगा।