我想绑定到ObservableCollection
XAML 中的一个并在那里应用分组。原则上,这工作得很好。
<UserControl.Resources>
<CollectionViewSource x:Key="cvs" Source="{Binding Path=TestTemplates}">
<CollectionViewSource.SortDescriptions>
<scm:SortDescription PropertyName="Title"/>
</CollectionViewSource.SortDescriptions>
<CollectionViewSource.GroupDescriptions>
<PropertyGroupDescription PropertyName="TestCategory"/>
</CollectionViewSource.GroupDescriptions>
</CollectionViewSource>
</UserControl.Resources>
然后数据绑定表达式变成ItemsSource="{Binding Source={StaticResource ResourceKey=cvs}}"
了ItemsSource="{Binding Path=TestTemplates}"
.
起初,一切看起来都很酷,直到我想从视图模型中刷新 UI。问题是,它CollectionViewSource.GetDefaultView(TestTemplates)
返回的视图与应用分组的 XAML 中的视图不同。因此,我无法设置选择或用它做任何有用的事情。
我可以通过将列表再次直接绑定到视图模型的属性并在代码隐藏中设置分组来修复它。但我对这个解决方案并不满意。
private void UserControlLoaded(object sender, RoutedEventArgs e)
{
IEnumerable source = TemplateList.ItemsSource;
var cvs = (CollectionView)CollectionViewSource.GetDefaultView(source);
if (cvs != null)
{
cvs.SortDescriptions.Add(new SortDescription("Title", ListSortDirection.Ascending));
cvs.GroupDescriptions.Add(new PropertyGroupDescription("TestCategory"));
}
}
尽管如此,我希望应该有一种方法来获得正确的观点。我错了吗?