Nota
L'accesso a questa pagina richiede l'autorizzazione. È possibile provare ad accedere o modificare le directory.
L'accesso a questa pagina richiede l'autorizzazione. È possibile provare a modificare le directory.
Esempio
In questo esempio viene illustrato come gestire i namespace specificati nell'origine di binding XML.
Se i dati XML hanno la definizione dello spazio dei nomi XML seguente:
<rss version="2.0" xmlns:dc="http://purl.org/dc/elements/1.1/">
È possibile utilizzare l'elemento XmlNamespaceMapping per mappare lo spazio dei nomi a un Prefix, come nell'esempio seguente. È quindi possibile usare il Prefix per fare riferimento allo spazio dei nomi XML. Il ListBox in questo esempio visualizza il titolo e dc:date di ogni elemento .
<StackPanel.Resources>
<XmlNamespaceMappingCollection x:Key="mapping">
<XmlNamespaceMapping Uri="http://purl.org/dc/elements/1.1/" Prefix="dc" />
</XmlNamespaceMappingCollection>
<XmlDataProvider Source="http://msdn.microsoft.com/subscriptions/rss.xml"
XmlNamespaceManager="{StaticResource mapping}"
XPath="rss/channel/item" x:Key="provider"/>
<DataTemplate x:Key="dataTemplate">
<Border BorderThickness="1" BorderBrush="Gray">
<Grid Width="600" Height="50">
<Grid.RowDefinitions>
<RowDefinition Height="25"/>
<RowDefinition Height="25"/>
</Grid.RowDefinitions>
<TextBlock Grid.Row="0" Text="{Binding XPath=title}" />
<TextBlock Grid.Row="1" Text="{Binding XPath=dc:date}" />
</Grid>
</Border>
</DataTemplate>
</StackPanel.Resources>
<ListBox
Width="600"
Height="600"
Background="Honeydew"
ItemsSource="{Binding Source={StaticResource provider}}"
ItemTemplate="{StaticResource dataTemplate}"/>
Si noti che il Prefix specificato non deve corrispondere a quello utilizzato nell'origine XML; se il prefisso cambia nell'origine XML, il mapping funziona ancora.
In questo particolare esempio, i dati XML provengono da un servizio Web, ma l'elemento XmlNamespaceMapping funziona anche con dati XML o XML inline in un file incorporato.
Vedere anche
.NET Desktop feedback