Jak sortować i grupować dane przy użyciu widoku w XAML

W tym przykładzie pokazano, jak utworzyć widok zbierania danych w języku XAML (Extensible Application Markup Language). Widoki umożliwiają grupowanie, sortowanie, filtrowanie i pojęcie bieżącego elementu.

Przykład

W poniższym przykładzie zasób statyczny o nazwie places jest definiowany jako kolekcja obiektów Place, w których każdy obiekt Place składa się z nazwy miasta i stanu. Prefiks src jest mapowany na przestrzeń nazw, w której zdefiniowano miejsce źródła danych. Prefiks scm mapuje na "clr-namespace:System.ComponentModel;assembly=WindowsBase" i 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 należy poprzedzić 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ż