XAML - डिबगिंग
यदि आप किसी प्रक्रियात्मक भाषा (जैसे C #, C / C ++ आदि) में डिबगिंग से परिचित हैं और आपको इसका उपयोग पता है breakऔर एक्सएएमएल में उसी तरह के डिबगिंग की उम्मीद कर रहे हैं, तो आपको यह जानकर आश्चर्य होगा कि एक्सएएमएल कोड को डीबग करना संभव नहीं है, जिस तरह से आप किसी अन्य प्रक्रियात्मक भाषा कोड को डीबग करते थे। XAML ऐप को डीबग करने का मतलब है कि एक त्रुटि खोजने की कोशिश करना;
डेटा बाइंडिंग में, आपका डेटा स्क्रीन पर दिखाई नहीं देता है और आपको पता नहीं है कि क्यों
या एक समस्या जटिल लेआउट से संबंधित है।
या सूची बॉक्स और कॉम्बो बॉक्स जैसे कुछ व्यापक टेम्पलेट्स के साथ मार्जिन रंग, ओवरले आदि में एक संरेखण मुद्दा या मुद्दे।
XAML में डिबगिंग एक ऐसी चीज है जिसे आप आमतौर पर यह जांचने के लिए करते हैं कि क्या आपके बाइंडिंग काम करते हैं, और यदि यह काम नहीं कर रहा है, तो यह जांचने के लिए कि क्या गलत है। दुर्भाग्य से, XAML बाइंडिंग में ब्रेकप्वाइंट सेट करना सिल्वरलाइट को छोड़कर संभव नहीं है, लेकिन हम डेटा बाइंडिंग त्रुटियों की जांच के लिए आउटपुट विंडो का उपयोग कर सकते हैं। डेटा बाइंडिंग में त्रुटि को खोजने के लिए निम्न 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 FirstName}"/>
</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;
}
}
}
यहाँ C # कोड में MainWindow क्लास का कार्यान्वयन है -
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();
}
}
}
चलिए इस एप्लिकेशन को चलाते हैं और आप तुरंत हमारे मेनविंडो में देख सकते हैं कि हम सफलतापूर्वक उस कर्मचारी के शीर्षक से बंध गए हैं लेकिन नाम बाध्य नहीं है।
नाम के साथ क्या हुआ, यह जांचने के लिए, आइए आउटपुट विंडो को देखें, जहां बहुत अधिक लॉग जेनरेट होता है।
एक त्रुटि खोजने का सबसे आसान तरीका है, बस त्रुटि की खोज करना और आपको नीचे उल्लिखित त्रुटि मिलेगी जो कहती है "बाइंडिंगएक्सप्रेशन पथ त्रुटि: 'FirstName' संपत्ति 'ऑब्जेक्ट' '' Employe" पर नहीं मिली
System.Windows.Data Error: 40 : BindingExpression path error: 'FirstName'
property not found on 'object' ''Employee' (HashCode = 11611730)'.
BindingExpression:Path = FirstName;
DataItem = 'Employee' (HashCode = 11611730); target element is 'TextBlock' (Name = '');
target property is 'Text' (type 'String')
जो स्पष्ट रूप से इंगित करता है कि फर्स्टनाम कर्मचारी वर्ग का सदस्य नहीं है, इसलिए यह आपके आवेदन में इस प्रकार के मुद्दों को ठीक करने में मदद करता है।
जब तुम बदल जाते हो FirstName सेवा Name फिर से, आप वांछित आउटपुट देखेंगे।
XAML के लिए UI डिबगिंग टूल
XAML के लिए UI डिबगिंग टूल रनटाइम पर XAML कोड का निरीक्षण करने के लिए विजुअल स्टूडियो 2015 के साथ पेश किए गए हैं। इन उपकरणों की मदद से, XAML कोड आपके चल रहे WPF एप्लिकेशन के विज़ुअल ट्री के रूप में प्रस्तुत किया गया है और पेड़ में विभिन्न UI तत्व गुण भी हैं। इस उपकरण को सक्षम करने के लिए, नीचे दिए गए चरणों का पालन करें।
Step 1 - टूल मेनू पर जाएं और टूल मेनू से विकल्प चुनें।
Step 2 - आपको निम्नलिखित डायलॉग बॉक्स देखने को मिलेगा।
Step 3 - बाईं ओर डिबगिंग आइटम के तहत सामान्य विकल्प पर जाएं।
Step 4 - हाइलाइट किए गए विकल्प की जांच करें, अर्थात, "XAML के लिए UI डिबगिंग उपकरण सक्षम करें"
Step 5 - ओके बटन दबाएं।
अब कोई भी XAML एप्लिकेशन चलाएं या निम्नलिखित XAML कोड का उपयोग करें -
<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>
जब एप्लिकेशन निष्पादित होता है, तो यह लाइव विज़ुअल ट्री दिखाएगा जहां सभी तत्व एक पेड़ में दिखाए गए हैं।
यह लाइव विजुअल ट्री यूआई तत्वों को रखे जाने को समझने के लिए पूर्ण लेआउट संरचना को दर्शाता है। लेकिन यह विकल्प केवल Visual Studio 2015 में उपलब्ध है। यदि आप Visual Studio के पुराने संस्करण का उपयोग कर रहे हैं, तो आप इस टूल का उपयोग नहीं कर सकते हैं; हालाँकि एक और उपकरण है जिसे विज़ुअल स्टूडियो के साथ एकीकृत किया जा सकता है जैसे विज़ुअल स्टूडियो के लिए XAML स्पाई। आप इससे डाउनलोड कर सकते हैंhttp://xamlspy.com/download। यदि आप Visual Studio के पुराने संस्करण का उपयोग कर रहे हैं तो हम आपको इस उपकरण को डाउनलोड करने की सलाह देते हैं।