5

因此,我一直在关注本指南以在 Windows 窗体控件上进行数据绑定(作者的疯狂道具,本指南很棒),并且我已经使用它来创建自定义类并将 a 绑定DataGridView到此类的集合:

class CompleteJobListEntry
{
    private string _jobName;
    private Image _jobStatus;
    private DateTime _jobAddedDate;
    private string _jobAddedScanner;
    private string _jobAddedUser;
    private string _jobLastActivity;
    private DateTime _jobActivityDate;
    private string _jobActivityUser;

    public string JobName { get { return _jobName; } set { this._jobName = value; } }
    public Image JobStatus { get { return _jobStatus; } set { this._jobStatus = value; } }
    public DateTime JobAddedDate { get { return _jobAddedDate; } set { this._jobAddedDate = value; } }
    public string JobAddedScanner { get { return _jobAddedScanner; } set { this._jobAddedScanner = value; } }
    public string JobAddedUser { get { return _jobAddedUser; } set { this._jobAddedUser = value; } }
    public string JobLastActivity { get { return _jobLastActivity; } set { this._jobLastActivity = value; } }
    public DateTime JobActivityDate { get { return _jobActivityDate; } set { this._jobActivityDate = value; } }
    public string JobActivityUser { get { return _jobActivityUser; } set { this._jobActivityUser = value; } }
}

此时,我从各种 SQL 数据库中导入了一堆数据来填充表,结果非常好。该指南甚至为添加过滤器提供了一个很好的起点,我打算稍后再跟进。不过,就目前而言,我坚持对新生成的DataGridView. 环顾四周,我发现它DataGridView有自己的 Sort 方法,可用如下:

completeJobListGridView.Sort(completeJobListGridView.Columns["JobName"], ListSortDirection.Ascending);

但是,当我尝试执行此操作时,我收到一条InvalidOperationException消息,告诉我“如果 DataGridView 控件绑定到不支持排序的 IBindingList,则无法对其进行排序。” 我找到了 IBindingList 和 IBindingListView 接口,但是让我的类继承这些接口中的任何一个都不能解决问题。

我该怎么做呢?我完全被困在这里......

4

1 回答 1

1

如果您的数据在一个集合中,您应该能够使用该BindingListView轻松地将排序功能添加到您的 DGV。请参阅如何实现 DataGridView 的自动排序?以及我对如何对绑定到 EF EntityCollection<T> 的 WinForms DataGridView 进行排序以获取更多信息和代码片段的回答。

于 2013-07-30T16:46:49.380 回答