WPF DataGrid 已填充,除非我使用 LINQ 来过滤其项目
-
20-08-2019 - |
题
我有一个简单的 WPFToolkit DataGrid
:
<Grid>
<dg:DataGrid Name="theDataGrid"/>
</Grid>
在简单的代码后面 Contact
班级:
public class Contact
{
public string FirstName { get; set; }
public string LastName { get; set; }
public Contact(string firstName, string lastName)
{
this.FirstName = firstName;
this.LastName = lastName;
}
}
在代码后面的主构造函数中,我构建了一个 List
集合并将其绑定到我的 DataGrid
:
List<Contact> contacts = new List<Contact>();
contacts.Add(new Contact("John", "Tester"));
contacts.Add(new Contact("Jill", "Tester"));
contacts.Add(new Contact("Joe", "Tester"));
contacts.Add(new Contact("Jimmy", "Nontester"));
theDataGrid.ItemsSource = contacts;
这工作正常,但如果我像这样使用 LINQ 过滤这些联系人:
List<Contact> contacts = new List<Contact>();
contacts.Add(new Contact("John", "Tester"));
contacts.Add(new Contact("Jill", "Tester"));
contacts.Add(new Contact("Joe", "Tester"));
contacts.Add(new Contact("Jimmy", "Nontester"));
var filteredContacts = contacts.Where(contact => contact.LastName.StartsWith("T"));
theDataGrid.ItemsSource = filteredContacts;
然后我的 DataGrid
已填充,但字段均为空 (!)。例如,在上面的例子中,我的 DataGrid
有三行都是空的。调试时奇怪的是, filteredContacts
包含四项。
如何使用 LINQ 来过滤我的自定义对象并让它们显示在我的 DataGrid
?
解决方案
我会尝试两件事:
改变
theDataGrid.ItemsSource = filteredContacts;
到
theDataGrid.ItemsSource = filteredContacts.ToList();
第二种是使用视图并在视图上进行过滤。
ListCollectionView view = (ListCollectionView)CollectionViewSource.GetDefaultView(contacts); view.Filter = delegate(object item) { return (item as Contact).LastName.StartsWith("T"); }; theDataGrid.ItemsSource = view;
不隶属于 StackOverflow