सिल्वरलाइट - डेटा बाइंडिंग
डेटा बाइंडिंग सिल्वरलाइट एप्लिकेशन में एक तंत्र है, जो डेटा के प्रदर्शन और बातचीत के लिए आंशिक कक्षाओं का उपयोग करके विंडोज रनटाइम ऐप्स के लिए एक सरल और आसान तरीका प्रदान करता है। डेटा का प्रबंधन पूरी तरह से अलग किया जाता है, जिस तरह से इस तंत्र में डेटा प्रदर्शित किया जाता है। डेटा बाइंडिंग UI तत्वों और उपयोगकर्ता इंटरफ़ेस पर डेटा ऑब्जेक्ट के बीच डेटा के प्रवाह की अनुमति देता है। जब कोई बंधन स्थापित होता है और डेटा या आपका व्यवसाय मॉडल बदलता है, तो यह UI तत्वों के लिए स्वचालित रूप से अपडेट को प्रतिबिंबित करेगा और इसके विपरीत। यह मानक डेटा स्रोत के लिए नहीं, बल्कि पृष्ठ पर किसी अन्य तत्व के लिए बाध्य करना भी संभव है।
डेटा बाइंडिंग निम्न दो प्रकार की होती है -
- एकतरफा डेटा बाइंडिंग
- दो-तरफ़ा डेटा बाइंडिंग
वन-वे डेटा बाइंडिंग
एक तरफ़ा डेटा बाइंडिंग में, डेटा अपने स्रोत (जो कि डेटा को धारण करने वाली वस्तु है) से उसके लक्ष्य से जुड़ा होता है (वह ऑब्जेक्ट जो डेटा प्रदर्शित करता है)।
आइए हम एक-तरफ़ा डेटा बाइंडिंग के सरल उदाहरण पर नज़र डालते हैं।
नीचे दिया गया XAML कोड है जिसमें दो लेबल, दो टेक्स्ट बॉक्स और एक बटन कुछ गुणों के साथ बनाए गए हैं।
<UserControl x:Class = "DataBinding.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"
mc:Ignorable = "d"
d:DesignHeight = "300" d:DesignWidth = "400">
<Grid x:Name = "LayoutRoot" Background = "White">
<Grid.RowDefinitions>
<RowDefinition Height = "Auto" />
<RowDefinition Height = "Auto" />
<RowDefinition Height = "*" />
</Grid.RowDefinitions>
<Grid.ColumnDefinitions>
<ColumnDefinition Width = "Auto" />
<ColumnDefinition Width = "200" />
</Grid.ColumnDefinitions>
<TextBlock Name = "nameLabel" Margin = "2">Name:</TextBlock>
<TextBox Name = "nameText" Grid.Column = "1" Margin = "2"
Text = "{Binding Name, Mode=OneWay}"/>
<TextBlock Name = "ageLabel" Margin = "2" Grid.Row = "1">Age:</TextBlock>
<TextBox Name = "ageText" Grid.Column = "1" Grid.Row = "1" Margin="2"
Text = "{Binding Age, Mode = OneWay}"/>
<StackPanel Grid.Row = "2" Grid.ColumnSpan = "2">
<Button Content = "_Show..." Click = "Button_Click" />
</StackPanel>
</Grid>
</UserControl>
हम निम्नलिखित बातों का पालन करते हैं -
दोनों टेक्स्ट बॉक्स के टेक्स्ट गुण "Name" तथा "Age”, जो कि वर्ग चर हैं Person नीचे दिखाया गया है।
में Person वर्ग, हमारे पास सिर्फ दो चर हैं Name तथा Age, और इसके ऑब्जेक्ट को इनिशियलाइज़ किया गया है MainPage कक्षा।
XAML कोड में, हम एक संपत्ति के लिए बाध्य कर रहे हैं Name और आयु, लेकिन हमने यह नहीं चुना कि संपत्ति किस वस्तु की है।
एक आसान तरीका यह है कि किसी वस्तु को कैसे निर्दिष्ट किया जाए DataContext जिनके गुण हम C # कोड में बांध रहे हैं MainPage निर्माता जैसा कि नीचे दिखाया गया है।
using System.Windows;
using System.Windows.Controls;
namespace DataBinding {
public partial class MainPage : UserControl {
Person person = new Person { Name = "Salman", Age = 26 };
public MainPage() {
InitializeComponent();
this.DataContext = person;
}
private void Button_Click(object sender, RoutedEventArgs e) {
string message = person.Name + " is " + person.Age;
MessageBox.Show(message);
}
}
public class Person {
private string nameValue;
public string Name {
get { return nameValue; }
set { nameValue = value; }
}
private double ageValue;
public double Age {
get { return ageValue; }
set {
if (value != ageValue) {
ageValue = value;
}
}
}
}
}
आइए हम इस एप्लिकेशन को चलाते हैं और आप तुरंत अपने वेबपेज में देख सकते हैं कि हमने उस व्यक्ति के नाम और आयु को सफलतापूर्वक बाध्य कर दिया है।
जब तुम दबाओगे Show बटन, यह संदेश बॉक्स में नाम और आयु प्रदर्शित करेगा।
हमें बदलने दो Name तथा Age उपरोक्त संवाद बॉक्स में।
अब, यदि आप क्लिक करते हैं Show बटन, यह फिर से एक ही संदेश प्रदर्शित करेगा।
इसकी वजह है data-bindingमोड XAML कोड में चालू करने के लिए सेट है। अद्यतन संदेश दिखाने के लिए, आपको दो-तरफ़ा डेटा बाइंडिंग को समझना होगा।
दो-तरफ़ा डेटा बाइंडिंग
में two-way bindingउपयोगकर्ता इंटरफ़ेस के माध्यम से डेटा को संशोधित करने में सक्षम है और उस डेटा को स्रोत में अपडेट किया गया है। यदि उपयोगकर्ता देखते समय स्रोत बदलता है, तो आप चाहते हैं कि दृश्य अपडेट किया जाए।
आइए हम एक ही उदाहरण पर एक नज़र डालते हैं, लेकिन केवल XAML कोड में बाइंडिंग मोड को दो तरफ़ा बाइंडिंग में बदलते हैं जैसा कि नीचे दिखाया गया है।
<UserControl x:Class = "DataBinding.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"
mc:Ignorable = "d"
d:DesignHeight = "300" d:DesignWidth = "400">
<Grid x:Name = "LayoutRoot" Background = "White">
<Grid.RowDefinitions>
<RowDefinition Height = "Auto" />
<RowDefinition Height = "Auto" />
<RowDefinition Height = "*" />
</Grid.RowDefinitions>
<Grid.ColumnDefinitions>
<ColumnDefinition Width = "Auto" />
<ColumnDefinition Width = "200" />
</Grid.ColumnDefinitions>
<TextBlock Name = "nameLabel" Margin = "2">_Name:</TextBlock>
<TextBox Name = "nameText" Grid.Column = "1" Margin = "2"
Text = "{Binding Name, Mode=TwoWay}"/>
<TextBlock Name = "ageLabel" Margin = "2" Grid.Row = "1">_Age:</TextBlock>
<TextBox Name = "ageText" Grid.Column = "1" Grid.Row = "1" Margin = "2"
Text = "{Binding Age, Mode = TwoWay}"/>
<StackPanel Grid.Row = "2" Grid.ColumnSpan = "2">
<Button Content = "_Show..." Click = "Button_Click" />
</StackPanel>
</Grid>
</UserControl>
आइए हम इस एप्लिकेशन को फिर से चलाते हैं और आप उसी आउटपुट को देख सकते हैं।
हमें बदलने दो Name तथा Age उपरोक्त संवाद बॉक्स में।
अब, यदि आप क्लिक करते हैं Show बटन यह अद्यतन संदेश प्रदर्शित करेगा।