如何:在 XAML 中使用视图对数据进行排序和分组

更新:2007 年 11 月

此示例演示如何在可扩展应用程序标记语言 (XAML) 中创建数据集的视图。使用视图可以进行分组、排序和筛选,并对当前项进行概念性说明。

示例

在下面的示例中,名为“地点”的静态资源定义为一组地点对象,其中的每个地点对象都由一个城市名称和相应的州/省/市/自治区名称组成。前缀 src 映射到其中定义了数据源地点 的命名空间。前缀 scmdat 分别映射到 System.ComponentModelSystem.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>

如果是绑定到在 XmlDataProvider 资源中定义的 XML 数据,请在 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

其他资源

数据绑定示例

数据绑定帮助主题