方法: XAML でビューを使用してデータを並べ替え、グループ化する
この例では、Extensible Application Markup Language (XAML) でデータ コレクションのビューを作成する方法を示します。 ビューを使用すると、グループ化、並べ替え、フィルター処理、および現在の項目の概念の機能を使用できます。
例
次の例では、場所 という名前の静的リソースは、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>
関連項目
- CollectionViewSource
- データ コレクション の既定のビューを取得する
- データ バインディングの概要
- 方法トピック
GitHub で Microsoft と共同作業する
このコンテンツのソースは GitHub にあります。そこで、issue や pull request を作成および確認することもできます。 詳細については、共同作成者ガイドを参照してください。
.NET Desktop feedback