我有一个简单的 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?

有帮助吗?

解决方案

我会尝试两件事:

  1. 改变

    theDataGrid.ItemsSource = filteredContacts;
    

    theDataGrid.ItemsSource = filteredContacts.ToList();
    
  2. 第二种是使用视图并在视图上进行过滤。

    ListCollectionView view = (ListCollectionView)CollectionViewSource.GetDefaultView(contacts);
    
    view.Filter = delegate(object item) { return (item as Contact).LastName.StartsWith("T"); };
    
    theDataGrid.ItemsSource = view;
    
许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top