共用方式為


如何:使用 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>

另請參閱