सिल्वरलाइट - मॉडल देखें

इस अध्याय में, हम सिल्वरलाइट के सॉफ्टवेयर विकास में एक महत्वपूर्ण तकनीक देख रहे हैं, का उपयोग View Models

  • view model एक महत्वपूर्ण टुकड़ा है, जो दृश्य से अलग मॉडल रखते हुए अलग प्रस्तुति नामक एक तकनीक का परिचय देता है।

  • View Models अलग-अलग प्रस्तुति प्राप्त करने का एक तरीका प्रदान करें, और हम देखेंगे कि वे आपके उपयोगकर्ता इंटरफ़ेस में आवश्यक कोड की मात्रा को कम करने के लिए सिल्वरलाइट के डेटा बाइंडिंग का शोषण कैसे करते हैं।

यूआई विकास चुनौतियां

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

  • यदि आप कम से कम प्रतिरोध के मार्ग का अनुसरण करते हैं जो विज़ुअल स्टूडियो के डिज़ाइन टूल आपको नीचे ले जाते हैं, तो आप बहुत अधिक कोड पीछे कोड में डाल सकते हैं।

  • यह देखने के लिए बहुत आम है कि बड़ी संख्या में अनुप्रयोग कार्यक्षमता पीछे के कोड में जोड़ दी जाती है।

  • कुछ डेवलपर्स वास्तव में उपयोगकर्ता इंटरफ़ेस वर्ग में व्यावसायिक तर्क रखने की योजना बनाते हैं, लेकिन क्योंकि विज़ुअल स्टूडियो आपके ईवेंट हैंडलर को लगाता है, यह चीजों को प्राप्त करने के लिए एक बहुत ही सुविधाजनक स्थान बन जाता है।

  • यह व्यापक रूप से स्वीकार किया जाता है कि यदि कक्षाओं में अच्छी तरह से परिभाषित किया गया है, और यथोचित संकीर्ण जिम्मेदारियां हैं, तो सॉफ्टवेयर को विकसित करना और बनाए रखना आसान है।

  • कोड के पीछे का काम उन वस्तुओं के साथ सीधे संपर्क करना है जो उपयोगकर्ता इंटरफ़ेस बनाते हैं जहां यह आवश्यक है।

  • जैसे ही आप कोड डालना शुरू करते हैं जो इस बारे में निर्णय लेता है कि आपका आवेदन वहां कैसे व्यवहार करता है जो समस्याओं को जन्म देता है।

  • न केवल तर्क कोड प्रवाह में उपयोग किया जा सकता है जो कि उपयोगकर्ता इंटरफ़ेस से संबंधित होना चाहिए, कुछ डेवलपर्स नियंत्रण पर भरोसा करना शुरू करते हैं, और अन्य उपयोगकर्ता इंटरफ़ेस ऑब्जेक्ट महत्वपूर्ण एप्लिकेशन स्थिति को रखने के लिए।

  • मॉडल केवल डेटा रखता है, दृश्य केवल स्वरूपित दिनांक रखता है, और नियंत्रक (ViewModel) दोनों के बीच संपर्क का कार्य करता है। नियंत्रक दृश्य से इनपुट ले सकता है और इसे मॉडल पर रख सकता है और इसके विपरीत।

अलग से प्रस्तुतिकरण

कोड के पीछे या XAML में एप्लिकेशन लॉजिक लगाने से होने वाली समस्याओं से बचने के लिए, एक तकनीक का उपयोग करना सबसे अच्छा है separated presentation। उपयोगकर्ता इंटरफ़ेस ऑब्जेक्ट्स के साथ सीधे काम करने के लिए न्यूनतम आवश्यकता के साथ XAML और कोड होने के बाद, एक उपयोगकर्ता इंटरफ़ेस कक्षाओं में जटिल इंटरैक्शन व्यवहार, एप्लिकेशन लॉजिक और बाकी सब चीजों के लिए कोड होता है जैसा कि नीचे बाईं ओर दिखाया गया है।

अलग प्रस्तुति की महत्वपूर्ण विशेषताएं -

  • अलग प्रस्तुति के साथ, उपयोगकर्ता इंटरफ़ेस वर्ग बहुत सरल है। इसमें XAML जरूर है, लेकिन पीछे कोड उतना ही व्यावहारिक है।

  • आवेदन तर्क एक अलग वर्ग में है, जिसे अक्सर कहा जाता है model

  • कई डेवलपर्स XAML में तत्वों को सीधे मॉडल में गुणों से जोड़ने के लिए डेटा बाइंडिंग का उपयोग करने का प्रयास करते हैं।

  • समस्या यह है model पूरी तरह से इस बात से संबंधित है कि एप्लिकेशन क्या करता है, और यह नहीं कि उपयोगकर्ता एप्लिकेशन के साथ कैसे इंटरैक्ट करता है।

  • अधिकांश उपयोगकर्ता इंटरफ़ेस में कुछ स्थिति होती है जो एप्लिकेशन मॉडल में नहीं होती है। उदाहरण के लिए, यदि आपका उपयोगकर्ता इंटरफ़ेस एक ड्रैग एंड ड्रॉप का उपयोग करता है, तो कुछ चीजों पर नज़र रखने की ज़रूरत है, जैसे कि आइटम को कहाँ खींचा जा रहा है, अभी ठीक है, इसकी उपस्थिति कैसे बदलनी चाहिए क्योंकि यह संभावित ड्रॉप लक्ष्य से आगे बढ़ता है, और उन ड्रॉप लक्ष्य भी कैसे हो सकते हैं आइटम के रूप में परिवर्तन उनके ऊपर खींच लिया जाता है।

  • इस तरह की स्थिति आश्चर्यजनक रूप से जटिल हो सकती है, और इसे पूरी तरह से जांचने की आवश्यकता है।

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

    • सबसे पहले, यह एक विशेष यूजर इंटरफेस दृश्य के लिए आपके एप्लिकेशन मॉडल को एडाप्ट करता है।

    • दूसरा, यह वह जगह है जहाँ कोई भी नॉनवेज इंटरेक्शन लॉजिक रहता है, और इसके द्वारा, मेरा मतलब है कि कोड को आपके यूजर इंटरफेस को प्राप्त करने के लिए आवश्यक है।

मॉडल / देखें / ViewModel

View Modelअलग प्रस्तुति दृष्टिकोण का एक उदाहरण है, लेकिन हमें स्पष्ट करना चाहिए कि प्रत्येक परत में हमारे पास किस प्रकार की चीज है। तीन परतें हैं -

  • Model
  • View
  • ViewModel

नमूना

यह है एक classic ऑब्जेक्ट मॉडल जिसमें साधारण सी # कक्षाएं शामिल हैं जिनका उपयोगकर्ता इंटरफ़ेस के साथ कोई सीधा संबंध नहीं है।

आप आमतौर पर अपने मॉडल कोड को किसी भी उपयोगकर्ता इंटरफ़ेस पुस्तकालयों के संदर्भ के बिना संकलन करने में सक्षम होने की उम्मीद करेंगे। वास्तव में, आप संभवतः ठीक उसी स्रोत कोड को लेने में सक्षम होंगे और इसे सिल्वरलाइट एप्लिकेशन, एक साधारण .NET कंसोल एप्लिकेशन या यहां तक ​​कि सर्वर-साइड वेब कोड में संकलित कर पाएंगे।

मॉडल के प्रकार उन अवधारणाओं का प्रतिनिधित्व करते हैं, जिनके साथ आपका एप्लिकेशन काम करता है।

राय

एक दृश्य आम तौर पर एक UserControl है, यह आपका MainPage हो सकता है, या यह आपके पृष्ठ का कुछ हिस्सा हो सकता है।

अधिकांश सिल्वरलाइट अनुप्रयोगों में, अपने उपयोगकर्ता इंटरफ़ेस को छोटे टुकड़ों में विभाजित करने के लिए एक उपयोगकर्ता को विभाजित करना एक अच्छा विचार है।

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

उदाहरण के लिए, यह परिभाषित करने के लिए बहुत आम है View एक सूची में एक व्यक्तिगत आइटम का प्रतिनिधित्व करने के लिए।

ViewModel

अंत में, प्रत्येक के लिए View, तुम लिखो ViewModel। तो, यह एक की महत्वपूर्ण विशेषताओं में से एक हैViewModel कक्षा।

यह एक विशेष दृश्य की सेवा के लिए मौजूद है। ViewModel चीजों को प्रस्तुत करने के एक विशेष तरीके के लिए विशिष्ट है, जैसे कि किसी विशेष डेटा आइटम के रूप में यह सूची में दिखाई देता है।

यही कारण है कि इसे ए कहा जाता है ViewModel; यह विशेष रूप से किसी विशेष दृश्य के लिए अंतर्निहित मॉडल को लागू करता है। मॉडल की तरह,ViewModelएक साधारण C # वर्ग भी है। इसे किसी विशेष प्रकार से प्राप्त करने की आवश्यकता नहीं है।

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

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

उदाहरण

आइए हम एक सरल उदाहरण देखें जिसमें हम उपयोग करेंगे Model-View-ViewModel (MVVM) दृष्टिकोण।

Step 1 - एक नया सिल्वरलाइट एप्लिकेशन प्रोजेक्ट बनाएं SilverlightMVVMDemo

Step 2 - नीचे दिखाए गए अनुसार अपनी परियोजना में तीन फ़ोल्डर्स (मॉडल, व्यूमॉडल, और दृश्य) जोड़ें।

Step 3 - मॉडल फोल्डर में एक StudentModel क्लास जोड़ें और उस क्लास में नीचे का कोड पेस्ट करें।

using System.ComponentModel; 
 
namespace SilverlightMVVMDemo.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)); 
         } 
      } 
   } 
}

Step 4 - ViewModel फ़ोल्डर में एक और StudentViewModel वर्ग जोड़ें और निम्नलिखित कोड पेस्ट करें।

using SilverlightMVVMDemo.Model; 
using System.Collections.ObjectModel;
  
namespace SilverlightMVVMDemo.ViewModel { 

   public class StudentViewModel { 
	
      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; 
      } 
   } 
}

Step 5 - जोड़ें Silverlight User Control पर राइट क्लिक करके Views फ़ोल्डर और चयन करें Add New Item…

Step 6- जोड़ें। अब आपको XAML फाइल दिखाई देगी। निम्नलिखित कोड जोड़ेंStudentView.xaml फ़ाइल, जिसमें विभिन्न UI तत्व हैं।

<UserControl x:Class = "SilverlightMVVMDemo.Views.StudentView" 
   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" 
   mc:Ignorable = "d" 
   d:DesignHeight = "300" d:DesignWidth = "400">
   
   <Grid x:Name = "LayoutRoot" Background = "White">
	
      <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>

Step 7 - अब जोड़ें StudentView तुम्हारे अंदर MainPage.xaml नीचे दिखाए अनुसार।

<UserControl x:Class = "SilverlightMVVMDemo.MainPage" 
   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:views = "clr-namespace:SilverlightMVVMDemo.Views" 
   mc:Ignorable = "d" 
   d:DesignHeight = "576.316" d:DesignWidth = "863.158"> 
   
   <Grid x:Name = "LayoutRoot" Background = "White"> 
      <views:StudentView x:Name = "StudentViewControl" Loaded = "StudentViewControl_Loaded"/> 
   </Grid> 
	
</UserControl>

Step 8 - यहाँ का कार्यान्वयन है Loaded में घटना MainPage.xaml.cs फ़ाइल, जो अद्यतन करेगा View वहाँ से ViewModel

using System.Windows; 
using System.Windows.Controls; 
 
namespace SilverlightMVVMDemo { 

   public partial class MainPage : UserControl { 
	
      public MainPage() { 
         InitializeComponent();
      }
   } 
	
   private void StudentViewControl_Loaded(object sender, RoutedEventArgs e) { 
      SilverlightMVVMDemo.ViewModel.StudentViewModel 
      studentViewModelObject = new SilverlightMVVMDemo.ViewModel.
      StudentViewModel(); 
      studentViewModelObject.LoadStudents();  
      StudentViewControl.DataContext = studentViewModelObject;  
   } 
}

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

यूआई बनाम व्यूमॉडल

एमवीवीएम दृष्टिकोण के सबसे कठिन हिस्सों में से एक काम कर रहा है जहां विभाजन रेखा आनी चाहिए। यह हमेशा स्पष्ट नहीं होता है कि कौन सी चीजें कहां से हैं।

  • विशेष रूप से, कुछ उपयोगकर्ता इंटरफ़ेस तत्व कार्यक्षमता प्रदान करते हैं, जो एक सख्त दृश्य के अनुसार, यकीनन व्यूमॉडल में होना चाहिए।

  • सामान्य तौर पर, सभी व्यवहार लागू नहीं होते हैं View ऐसे हैं ViewModel अनुकूल।

  • इसका कारण यह है कि पुन: उपयोग के लिए ViewModel व्यवहार को पैकेज करने का कोई मानक तरीका नहीं है, खासकर यदि आप किसी डिज़ाइन वातावरण का उपयोग करना चाहते हैं, जैसे कि Visual Studio, या Blend।

MVVM के लाभ

MVVM निम्नलिखित लाभ प्रदान करता है -

  • प्रस्तुति चिंताओं का पृथक्करण (देखें, दृश्यमॉडल, मॉडल)

  • स्वच्छ परीक्षण योग्य और प्रबंधनीय कोड। इकाई परीक्षण में प्रस्तुति स्तरीय तर्क शामिल कर सकते हैं।

  • कोड के पीछे कोई कोड नहीं है, इसलिए प्रस्तुति परत और तर्क शिथिल युग्मित है।

  • डेटाबाइंडिंग का बेहतर तरीका।

एमवीवीएम के नुकसान

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