Поделиться через


Практическое руководство. Сортировка и группировка данных с помощью представления в XAML

Обновлен: Ноябрь 2007

В этом примере демонстрируется создание представления коллекции данных в Язык XAML (Extensible Application Markup Language). Представления предоставляют возможность группировки, сортировки, фильтрации и категоризации текущего элемента.

Пример

В следующем примере статический ресурс places определяется как коллекция объектов Place, в которой каждый объект Place состоит из названия города и штата. Префикс src обозначает пространство имен, в котором определяется источник данных Places. Префиксы scm и dat обозначают пространства имен System.ComponentModel и System.Windows.Data соответственно.

В следующем примере создается представление коллекции данных, отсортированных по названию города и сгруппированных по штату.

<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>

Представление может быть источником привязки, как в следующем примере.

<ListBox ItemsSource="{Binding Source={StaticResource cvs}}"
         DisplayMemberPath="CityName" Name="lb">
  <ListBox.GroupStyle>
    <x:Static Member="GroupStyle.Default"/>
  </ListBox.GroupStyle>
</ListBox>

Для привязки к данным XML, определенным в ресурсе XmlDataProvider, укажите перед именем XML символ @.

<XmlDataProvider x:Key="myTasks" XPath="Tasks/Task">
    <x:XData>
        <Tasks >
            <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>

Полный пример см. в разделе Пример сортировки и группировки данных в XAML.

См. также

Задачи

Практическое руководство. Получение представления по умолчанию для коллекции данных

Основные понятия

Общие сведения о связывании данных

Ссылки

CollectionViewSource

Другие ресурсы

Примеры привязки данных

Практические руководства по привязке данных