所以这不是一个真正的问题,而是我过去 3 天遇到的问题的解决方案,欢迎任何改进。所以我有一个显示所选产品的数据网格,每个产品也可以有称为成分的子项,这些成分应该添加到集合中,但不向用户显示。
我为此提出的解决方案如下。注释掉的 where 条款是我的第一次尝试。
public ObservableCollection<ProductSaleTransaction> gProductSale = new ObservableCollection<ProductSaleTransaction>();
public ObservableCollection<ProductSaleTransaction> ProductSaleCollection
{
get { return gProductSale/*.Where(s => s.category != "Ingredients").ToObservableCollection<ProductSaleTransaction>()*/; }
}
private void Window_Loaded(object sender, RoutedEventArgs e)
{
dgProductTchSale.ItemsSource = ProductSaleCollection;
ProductSaleCollection.CollectionChanged += ProductSaleCollection_CollectionChanged;
}
private void ProductSaleCollection_CollectionChanged(object sender, System.Collections.Specialized.NotifyCollectionChangedEventArgs e)
{
ICollectionView view = CollectionViewSource.GetDefaultView(ProductSaleCollection);
view.Filter = new Predicate<object>(filterIngredient);
}
public bool filterIngredient(object item)
{
var vaitem = (ProductSaleTransaction)item;
if (vaitem == null)
return false;
else
{
bool it = false;
it = vaitem.category != "Ingredient";
return it;
}
}
这会导致向用户显示添加到集合中的所有项目,但仅显示不在成分类别中的项目。
这就是我想出的来解决我想用所有下游代码保存到数据库但不向用户显示的项目的自动过滤问题。
当ICollectionView
的基础集合添加/删除项时,将自动评估其筛选器。因此,无需在每次集合更改时创建新ICollectionView
。
而是移动线条
ICollectionView view = CollectionViewSource.GetDefaultView(ProductSaleCollection);
view.Filter = new Predicate<object>(filterIngredient);
以Window_Loaded
自身并删除ProductSaleCollection_CollectionChanged
事件。