以下示例创建了一个简单的 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 项添加到ListBoxItemCollection中,并且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 列进行排序 数据绑定概述 在视图中筛选数据 操作说明主题