以下示例创建了一个简单的
ListBox
和一个
Button
:
<Window x:Class="ListBoxSort_snip.Window1"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
Title="ListBoxSort_snip" Height="300" Width="300">
<DockPanel>
<ListBox Name="myListBox" DockPanel.Dock="Top">
<ListBoxItem>my</ListBoxItem>
<!--Or you can set the content this way:-->
<!--<ListBoxItem Content="my"/>-->
<ListBoxItem>1</ListBoxItem>
<ListBoxItem>Sort</ListBoxItem>
<ListBoxItem>3</ListBoxItem>
<ListBoxItem>ListBox</ListBoxItem>
<ListBoxItem>2</ListBoxItem>
</ListBox>
<Button Click="OnClick" Width="30" Height="20" DockPanel.Dock="Top">Sort</Button>
</DockPanel>
</Window>
按钮 Click 的事件处理程序包含按降序对项 ListBox 进行排序的逻辑。 可以这样做是因为以这种方式将ListBox 项添加到ListBox的ItemCollection中,并且ItemCollection是从CollectionView类派生的。 如果您要使用ItemsSource属性将ListBox绑定到集合,可以用相同的技术来实现排序。
private void OnClick(object sender, RoutedEventArgs e)
myListBox.Items.SortDescriptions.Add(
new SortDescription("Content", ListSortDirection.Descending));
Private Sub OnClick(ByVal sender As Object, ByVal e As RoutedEventArgs)
myListBox.Items.SortDescriptions.Add(New SortDescription("Content", ListSortDirection.Descending))
End Sub
只要具有对视图对象的引用,就可以使用相同的技术对其他集合视图的内容进行排序。 有关如何获取视图的示例,请参阅 “获取数据收集的默认视图”。 有关另一个示例,请参阅 单击标题时对 GridView 列进行排序。 有关视图的详细信息,请参阅 数据绑定概述中的“绑定到集合”。
有关如何在可扩展应用程序标记语言(XAML)中应用排序逻辑的示例,请参阅 使用 XAML 中的视图对数据进行排序和分组。
CustomSort
在标题获得单击时对 GridView 列进行排序
数据绑定概述
在视图中筛选数据
操作说明主题