Instrukcje: sortowanie i grupowanie danych przy użyciu widoku w języku XAML
W tym przykładzie pokazano, jak utworzyć widok zbierania danych w języku XAML (Extensible Application Markup Language). Widoki umożliwiają funkcjonalności grupowania, sortowania, filtrowania oraz pojęcie aktualnie wybranego elementu.
Przykład
W poniższym przykładzie zasób statyczny o nazwie definiuje się jako kolekcja obiektów Place, z których każdy obiekt Place składa się z nazwy miasta i stanu. Prefiks src jest odwzorowywany do przestrzeni nazw, w której zdefiniowano źródło danych Miejsca. Prefiks scm mapuje na "clr-namespace:System.ComponentModel;assembly=WindowsBase"
, a dat mapuje na "clr-namespace:System.Windows.Data;assembly=PresentationFramework"
.
Poniższy przykład tworzy widok zbierania danych posortowany według nazwy miasta i pogrupowany według stanu.
<Window.Resources>
<src:Places x:Key="places"/>
<CollectionViewSource Source="{StaticResource places}" x:Key="cvs">
<CollectionViewSource.SortDescriptions>
<scm:SortDescription PropertyName="CityName"/>
</CollectionViewSource.SortDescriptions>
<CollectionViewSource.GroupDescriptions>
<dat:PropertyGroupDescription PropertyName="State"/>
</CollectionViewSource.GroupDescriptions>
</CollectionViewSource>
Następnie widok może być źródłem powiązania, jak w poniższym przykładzie:
<ListBox ItemsSource="{Binding Source={StaticResource cvs}}"
DisplayMemberPath="CityName" Name="lb">
<ListBox.GroupStyle>
<x:Static Member="GroupStyle.Default"/>
</ListBox.GroupStyle>
</ListBox>
W przypadku powiązań z danymi XML zdefiniowanymi w zasobie XmlDataProvider poprzedzaj nazwę XML symbolem @.
<XmlDataProvider x:Key="myTasks" XPath="Tasks/Task">
<x:XData>
<Tasks xmlns="">
<Task Name="Groceries" Priority="2" Type="Home">
<CollectionViewSource x:Key="mySortedTasks"
Source="{StaticResource myTasks}">
<CollectionViewSource.SortDescriptions>
<scm:SortDescription PropertyName="@Priority" />
</CollectionViewSource.SortDescriptions>
<CollectionViewSource.GroupDescriptions>
<dat:PropertyGroupDescription PropertyName="@Priority" />
</CollectionViewSource.GroupDescriptions>
</CollectionViewSource>
Zobacz też
- CollectionViewSource
- Pobierz domyślny widok kolekcji danych
- Omówienie powiązania danych
- Tematy poradnikowe
.NET Desktop feedback