सिल्वरलाइट - एक्सएएमएल अवलोकन
सिल्वरलाइट के साथ काम करते समय आपका सामना करने वाली पहली चीजों में से एक XAML है। एक्सएएमएल एक्स्टेंसिबल एप्लिकेशन मार्कअप लैंग्वेज के लिए खड़ा है। यह XML पर आधारित एक सरल और घोषित भाषा है।
XAML में, पदानुक्रमित संबंधों के साथ किसी ऑब्जेक्ट के गुण बनाना, आरंभ करना और सेट करना बहुत आसान है।
यह मुख्य रूप से GUI डिजाइन करने के लिए उपयोग किया जाता है।
इसका उपयोग अन्य उद्देश्यों के लिए भी किया जा सकता है, उदाहरण के लिए, वर्कफ़्लो नींव में वर्कफ़्लो घोषित करने के लिए।
बेसिक सिंटेक्स
जब आप एक नया सिल्वरलाइट प्रोजेक्ट बनाते हैं, तो आप डिफ़ॉल्ट रूप से कुछ XAML कोड देखेंगे MainPage.xaml जैसा की नीचे दिखाया गया।
<UserControl x:Class = "FirstExample.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>
</UserControl>
आप देख सकते हैं कि ऊपर दी गई XAML फाइल में विभिन्न प्रकार की जानकारी का उल्लेख है; उन सभी को संक्षेप में नीचे दी गई तालिका में वर्णित किया गया है।
जानकारी | विवरण |
---|---|
<UserControl | एक नए नियंत्रण को परिभाषित करने के लिए आधार वर्ग प्रदान करता है जो मौजूदा नियंत्रणों को अलग करता है और अपना तर्क प्रदान करता है। |
x: कक्षा = "FirstExample.MainPage" | यह एक आंशिक वर्ग घोषणा है, जो मार्कअप को उस आंशिक वर्ग कोड के पीछे जोड़ता है, जो इसमें परिभाषित है। |
xmlns = "http://schemas.microsoft.com / winfx / 2006 / xaml / प्रस्तुति" | सिल्वरलाइट क्लाइंट / फ्रेमवर्क के लिए डिफ़ॉल्ट XAML नामस्थान को मैप करें। |
xmlns: x = "http: //schemas.microsoft.c om / winfx / 2006 / xaml" | XAML भाषा के लिए XAML नामस्थान, जो इसे x: उपसर्ग में मैप करता है। |
xmlns: d = "http://schemas.microsoft.com / अभिव्यक्ति / मिश्रण / 2008" | XAML नाम स्थान डिज़ाइनर समर्थन के लिए अभिप्रेत है, विशेष रूप से Microsoft Visual Studio और Microsoft अभिव्यक्ति मिश्रण के XAML डिज़ाइन सतहों में डिज़ाइनर समर्थन। |
xmlns: mc = "http: //schemas.openxmlforma ts.org/markup-compatit/2006" | इंगित करता है और XAML पढ़ने के लिए एक मार्कअप संगतता मोड का समर्थन करता है। |
> | जड़ के वस्तु तत्व का अंत। |
<ग्रिड> </ ग्रिड> | ये एक खाली ग्रिड ऑब्जेक्ट का शुरुआती और समापन टैग हैं। |
</ UserControl> | वस्तु तत्व को बंद करना। |
एक्सएएमएल के लिए सिंटैक्स नियम एक्सएमएल के लगभग समान हैं। यदि आप एक XAML दस्तावेज़ को देखते हैं, तो आप देखेंगे कि वास्तव में यह एक वैध XML फ़ाइल है। इसका उल्टा सच नहीं है, क्योंकि XML में, विशेषताओं का मूल्य एक स्ट्रिंग होना चाहिए जबकि XAML में यह एक अलग वस्तु हो सकती है जिसे संपत्ति तत्व सिंटैक्स के रूप में जाना जाता है।
एक वस्तु तत्व का सिंटैक्स एक बाएं कोण ब्रैकेट (<) के साथ शुरू होता है, जिसके बाद एक ऑब्जेक्ट का नाम होता है, जैसे बटन।
उस वस्तु तत्व के गुणों और विशेषताओं को परिभाषित किया गया है।
ऑब्जेक्ट तत्व को आगे की ओर स्लैश (/) द्वारा बंद किया जाना चाहिए, जिसके तुरंत बाद एक समकोण कोष्ठक (>) होगा।
बिना किसी बाल तत्व के एक साधारण वस्तु का उदाहरण नीचे दिखाया गया है।
<Button/>
कुछ विशेषताओं के साथ एक वस्तु तत्व का उदाहरण -
<Button Content = "Click Me" Height = "30" Width = "60"/>
गुणों को परिभाषित करने के लिए एक वैकल्पिक सिंटैक्स का उदाहरण (संपत्ति तत्व सिंटैक्स) -
<Button>
<Button.Content>Click Me</Button.Content>
<Button.Height>30</Button.Height>
<Button.Width>60</Button.Width>
</Button>
बाल तत्व के साथ एक वस्तु का उदाहरण: StackPanel में बाल तत्व के रूप में टेक्स्टब्लॉक शामिल है।
<StackPanel Orientation = "Horizontal">
<TextBlock Text = "Hello"/>
</StackPanel/>
सिल्वरलाइट में XAML क्यों
XAML मूल रूप से सिल्वरलाइट के लिए आविष्कार नहीं किया गया था। यह WPF, विंडोज प्रेजेंटेशन फाउंडेशन से आया है। सिल्वरलाइट को अक्सर WPF का सबसेट कहा जाता है। यह कड़ाई से सच नहीं है, क्योंकि सिल्वरलाइट कुछ ऐसी चीजें कर सकती है जो WPF नहीं कर सकती। यहां तक कि जहां कार्यक्षमता ओवरलैप होती है, दोनों विवरणों में थोड़ा भिन्न होते हैं।
यह कहना अधिक सटीक है कि WPF और सिल्वरलाइट कई मामलों में बहुत समान हैं। मतभेदों के बावजूद, XAML फ़ीचर सिल्वरलाइट ने WPF से उधार लिया है, यह देखना अभी भी जानकारीपूर्ण है। उदाहरण के लिए, सिल्वरलाइट बिटमैप्स और स्केलेबल आकृतियों के लिए ग्राफिक्स प्रिमिटिव प्रदान करता है।
यह वीडियो और ऑडियो प्रदान करने के लिए तत्व भी प्रदान करता है।
इसमें सरल स्वरूपित पाठ समर्थन है, और आप किसी भी तत्व को एनिमेट कर सकते हैं। यदि आप WPF जानते हैं, तो यह सुविधा सेट आपके लिए परिचित होगा।
एक महत्वपूर्ण बिंदु, आप WPF XAML नहीं ले सकते हैं और इसका उपयोग सिल्वरलाइट में कर सकते हैं।
हालांकि समानताएं हैं, आप कई छोटे अंतर भी पाएंगे।
XAML और कोड के पीछे
XAML उपयोगकर्ता इंटरफ़ेस की उपस्थिति और संरचना को परिभाषित करता है। हालाँकि, यदि आप चाहते हैं कि आपका एप्लिकेशन उपयोगकर्ता के साथ बातचीत करने के दौरान कुछ उपयोगी काम करे, तो आपको कुछ कोड की आवश्यकता होगी।
प्रत्येक XAML फ़ाइल आमतौर पर एक स्रोत कोड फ़ाइल से जुड़ी होती है, जिसे हम पीछे के कोड के रूप में संदर्भित करते हैं। विभिन्न Microsoft फ्रेमवर्क इस शब्द का उपयोग करते हैं।
पीछे कोड को आमतौर पर XAML में परिभाषित तत्वों का उपयोग करने की आवश्यकता होगी, या तो उपयोगकर्ता इनपुट के बारे में जानकारी प्राप्त करने के लिए, या उपयोगकर्ता को जानकारी दिखाने के लिए।
नीचे दिए गए XAML कोड में, TextBlock तथा Buttonपरिभाषित किया गया हैं। डिफ़ॉल्ट रूप से, जब एप्लिकेशन चलाया जाता है, तो यह एक टेक्स्ट दिखाएगा “Hello World!“वेब पेज और एक बटन पर।
<UserControl x:Class = "FirstExample.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">
<StackPanel>
<TextBlock x:Name = "TextMessage"
Text = "Hello World!"
Margin = "5">
</TextBlock>
<Button x:Name = "ClickMe"
Click = "ClickMe_Click"
Content = "Click Me!"
Margin = "5">
</Button>
</StackPanel>
</Grid>
</UserControl>
पीछे वाला कोड किसी भी तत्व को एक्सेस कर सकता है जिसका नाम है x:Name निर्देश।
नामांकित तत्व पीछे के कोड में फ़ील्ड के माध्यम से उपलब्ध हो जाते हैं, जिससे कोड इन वस्तुओं और उनके सदस्यों को सामान्य तरीके से एक्सेस कर सकता है।
x:Prefix यह दर्शाता है कि नाम एक सामान्य संपत्ति नहीं है।
x:Name XAML संकलक के लिए एक विशेष संकेत है जिसे हम कोड के पीछे इस ऑब्जेक्ट तक पहुंचना चाहते हैं।
नीचे दिया गया बटन-क्लिक इवेंट कार्यान्वयन है जिसमें TextBlock पाठ अद्यतन किया गया है।
using System.Windows;
using System.Windows.Controls;
namespace FirstExample {
public partial class MainPage : UserControl {
public MainPage() {
InitializeComponent();
}
private void ClickMe_Click(object sender, RoutedEventArgs e) {
TextMessage.Text = "Congratulations! you have created your first Silverlight Applicatoin";
}
}
}
XAML यूआई तत्वों को डिजाइन करने का एकमात्र तरीका नहीं है। यह आपको XAML में वस्तुओं को घोषित करने या एक कोड में घोषित / लिखने के लिए है।
XAML वैकल्पिक है, लेकिन इसके बावजूद, यह दिल है Silverlight डिज़ाइन।
XAML कोडिंग के साथ लक्ष्य विजुअल डिजाइनरों को सीधे उपयोगकर्ता इंटरफ़ेस तत्व बनाने में सक्षम करना है। इसलिए,Silverlight इसका उद्देश्य उपयोगकर्ता इंटरफ़ेस के सभी दृश्य पहलुओं को मार्क-अप से नियंत्रित करना संभव है।