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

此示例演示如何使用 Extensible Application Markup Language (XAML) 创建数据收集视图。 视图支持对当前项进行分组、排序、筛选和表示的功能。

示例

以下示例将名为“places”的静态资源定义为 Place 对象的集合,其中每个 Place 对象包含一个城市名称和州。 前缀 src 映射到定义数据源 Places 的命名空间。 前缀 scm 映射到 "clr-namespace:System.ComponentModel;assembly=WindowsBase",dat 映射到 "clr-namespace:System.Windows.Data;assembly=PresentationFramework"

以下示例将创建一个数据收集视图,该视图按城市名称排序并按州分组。

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

另请参阅