XAML - डाटा बाइंडिंग

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

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

  • एकतरफा डेटा बाइंडिंग
  • दो-तरफ़ा डेटा बाइंडिंग

वन-वे डेटा बाइंडिंग

एक-तरफ़ा बाइंडिंग में, डेटा अपने स्रोत (जो ऑब्जेक्ट डेटा को रखता है) से उसके लक्ष्य से जुड़ा होता है (वह ऑब्जेक्ट जो डेटा प्रदर्शित करता है)।

आइए एक-तरफ़ा डेटा बाइंडिंग के सरल उदाहरण पर एक नज़र डालते हैं। निम्नलिखित XAML कोड कुछ गुणों के साथ चार टेक्स्ट ब्लॉक बनाता है।

<Window x:Class = "DataBindingOneWay.MainWindow" 
   xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation" 
   xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml" 
   Title = "MainWindow" Height = "350" Width = "604"> 
	
   <Grid>
      <StackPanel Name = "Display">
         <StackPanel Orientation = "Horizontal" Margin = "50, 50, 0, 0"> 
            <TextBlock Text = "Name: " Margin = "10" Width = "100" /> 
            <TextBlock Margin = "10" Width = "100" Text = "{Binding Name}" />
         </StackPanel> 
		
         <StackPanel Orientation = "Horizontal" Margin = "50,0,50,0"> 
            <TextBlock Text = "Title: " Margin = "10" Width = "100" /> 
            <TextBlock Margin = "10" Width = "100" Text = "{Binding Title}" /> 
         </StackPanel>
      </StackPanel>
   </Grid> 
	
</Window>

दो टेक्स्ट ब्लॉक की टेक्स्ट प्रॉपर्टीज "नाम" और "टाइटल" स्टेटिकली सेट की जाती हैं, जबकि अन्य दो टेक्स्ट ब्लॉक टेक्स्ट प्रॉपर्टीज "नेम" और "टाइटल" से बंधे होते हैं, जो कि एम्प्लॉई क्लास के क्लास वेरिएबल होते हैं, जो नीचे दिखाया गया है।

using System; 
using System.Collections.Generic; 
using System.Linq; 
using System.Text; 
using System.Threading.Tasks; 
 
namespace DataBindingOneWay {
   public class Employee {
      public string Name { get; set; } 
      public string Title { get; set; }  
		
      public static Employee GetEmployee() {
         var emp = new Employee() { 
            Name = "Ali Ahmed", Title = "Developer" 
         }; 
         return emp; 
      }
   }
}

इस वर्ग में, हमारे पास केवल दो चर हैं, Name तथा Title, और एक स्टैटिक तरीका है जिसमें कर्मचारी ऑब्जेक्ट को इनिशियलाइज़ किया जाता है जो उस कर्मचारी ऑब्जेक्ट को वापस कर देगा। इसलिए हम एक संपत्ति, नाम और शीर्षक के लिए बाध्य हैं, लेकिन हमने यह नहीं चुना है कि वह संपत्ति किस वस्तु की है। सबसे आसान तरीका है DataContext के लिए एक वस्तु निर्दिष्ट करना जिसके गुण हम निम्नलिखित C # कोड में बाँध रहे हैं -

using System; 
using System.Windows; 
using System.Windows.Controls;

namespace DataBindingOneWay { 
   /// <summary> 
      /// Interaction logic for MainWindow.xaml 
   /// </summary> 
	
   public partial class MainWindow : Window {
      public MainWindow() { 
         InitializeComponent(); 
         DataContext = Employee.GetEmployee(); 
      } 
   }
}

आइए इस एप्लिकेशन को चलाएं और आप तुरंत हमारे मेनविंडो में देख सकते हैं कि हम उस कर्मचारी वस्तु के नाम और शीर्षक से सफलतापूर्वक बंध गए हैं।

टू-वे डेटा बाइंडिंग

दो-तरफ़ा बाइंडिंग में, उपयोगकर्ता डेटा को उपयोगकर्ता इंटरफ़ेस के माध्यम से संशोधित कर सकता है और उस डेटा को स्रोत में अपडेट कर सकता है। यदि उपयोगकर्ता देखते समय स्रोत बदल जाता है, तो आप दृश्य को अपडेट करना चाहेंगे।

उदाहरण

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

<Window x:Class = "XAMLTestBinding.MainWindow" 
   xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation" 
   xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml" 
   Title = "MainWindow" Height = "350" Width = "604"> 
	
   <StackPanel>
      <ComboBox Name = "comboBox"  Margin = "50" Width = "100"> 
         <ComboBoxItem Content = "Green" /> 
         <ComboBoxItem Content = "Yellow" IsSelected = "True" /> 
         <ComboBoxItem Content = "Orange" /> 
      </ComboBox>
		
      <TextBox  Name = "textBox" Margin = "50" 
         Width = "100" Height = "23" VerticalAlignment = "Top" 
         Text  = "{Binding ElementName = comboBox, Path = SelectedItem.Content, 
         Mode = TwoWay, UpdateSourceTrigger = PropertyChanged}" 
         Background = "{Binding ElementName = comboBox, Path = SelectedItem.Content}"> 
      </TextBox>
   </StackPanel> 
	
</Window>

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

इसी तरह, जब उपयोगकर्ता टेक्स्टबॉक्स में एक वैध रंग नाम टाइप करता है, तो कॉम्बोक्स और टेक्स्टबॉक्स पृष्ठभूमि रंग भी अपडेट किया जाएगा।