如何过滤我的DataGrid? 此代码不起作用:WPF DataGrid过滤器不起作用
public MainWindow()
{
InitializeComponent();
SetSource();
}
private void FilterTextBox_TextChanged(object sender, TextChangedEventArgs e)
{
}
void SetSource()
{
CollectionViewSource Sorted = new CollectionViewSource() { Source = MainDB.CurDB.Requests };
Sorted.SortDescriptions.Add(new SortDescription("Id", ListSortDirection.Descending));
Sorted.Filter += Sorted_Filter;
MainDataGrid.ItemsSource = Sorted.View;
}
private void Sorted_Filter(object sender, FilterEventArgs e)
{
e.Accepted = true;
}
例外,我得到:
"System.Windows.Data.BindingListCollectionView" It does not support filtering
更新: 过滤器是现在的工作,但现在我得到以下错误,打破列:
System.Windows.Data Error: 40 : BindingExpression path error: 'Changing Date' property not found on 'object' ''RequestsRow' (HashCode=56483442)'. BindingExpression:Path=Changing Date; DataItem='RequestsRow' (HashCode=56483442); target element is 'TextBlock' (Name=''); target property is 'Text' (type 'String')
当某些单元格保持空时,会出现问题
我的数据集。没有其他类我有:
问题被替换 “SM ID” “SM_ID” 解决等
试试这个:'ICollectionView排序= CollectionViewSource.GetDefaultView(MainDB.CurDB.Requests);''而不是'CollectionViewSource Sorted = new CollectionViewSource(){Source = MainDB.CurDB.Requests};' – Pikoh
ICollectionView Sorted = CollectionViewSource.GetDefaultView(MainDB.CurDB.Requests); Sorted.Filter = item => true;抛出异常(“ 该方法不支持”) – DenisJNewb
好吧,尝试'ICollectionView Sorted = CollectionViewSource.GetDefaultView(MainDB.CurDB.Requests.AsEnumerable()); Sorted.Filter = item => true;' – Pikoh