从昨天开始,我一直在寻找解决问题的方法。我用 MVVM 模式构建了一个问题。我有两个用户控件,它们都包含一个列表框。
第一个用户控件称为 SearchView,其中包含项目名称列表框,用户可以选择并保存到应用程序本地数据库中。
添加选定项目时,会触发一个事件,通知名为“ProjectView”的第二个用户控件。此用户控件仅显示本地保存的项目。见下图。
问题是我希望能够在项目视图中按名称升序对列表框进行排序。因此,如果用户首先添加“Test Project 2”,然后添加“Test Project 1”,则“Test Project 1”会显示在列表框的顶部。
我曾尝试使用 ICollectionView 和 ListCollectionView 但我现在真的很困惑。
所以现在我的代码看起来像这样,在需要对列表框进行排序的 ProjectViewModel 中:
public ProjectViewModel() {
this.collectionView = CollectionViewSource.GetDefaultView(this.Projects);
}
private ObservableCollection<ProjectWrapper> _project = new ObservableCollection<ProjectWrapper>();
public ObservableCollection<ProjectWrapper> Projects
{
get { return _project; }
set
{
_project = value;
OnPropertyChanged("Projects");
}
}
XAML 代码:
<UserControl.Resources>
<CollectionViewSource x:Key="cvs" Source="{Binding Path=Projects}">
<CollectionViewSource.SortDescriptions>
<scm:SortDescription PropertyName="ProjectWrapper.Project.Name" />
</CollectionViewSource.SortDescriptions>
</CollectionViewSource>
</UserControl.Resources>
<ListBox Name="ProjectsList" ItemsSource="{Binding Source={StaticResource cvs}}" SelectedItem="{Binding Path=SelectedProject}" HorizontalContentAlignment="Stretch" BorderThickness="0" Grid.Row="1" Grid.RowSpan="3" Margin="0,0.4,-0.2,27.8">
<ListBox.ItemTemplate>
<DataTemplate>
<DockPanel>
<TextBlock Text="{Binding Path=ProjectModel.Name}" HorizontalAlignment="Left" VerticalAlignment="Center" Padding="3,2,0,0" />
<CheckBox IsChecked="{Binding Path=IsSelected, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}" HorizontalAlignment="Right" VerticalAlignment="Center" Padding="0,2,5,0" Margin="0,2.5,0,0" />
</DockPanel>
</DataTemplate>
</ListBox.ItemTemplate>
</ListBox>
提前致谢