How to Sort a BindingList - 对BindingList排序
手上有一个DataGridView,绑定了一个BindingList。BindingList声明如下:
private BindingList<Report> reportsInGrid;
Report有一个property名为DisplayOrder,现在需要在DisplayOrder改变时立即对List重新排序。拟在CellEndEdit事件中处理排序。
注意到BindingList本身并没提供Sort方法,而DataGridView本身提供了两个重载的Sort()方法,于是做了如下尝试:
方法1:DataGridView的第一个Sort方法签名如下:
public virtual void Sort(IComparer comparer)
使用后提示当DataGridView的virtualMode为true时不能使用该方法排序。失败。方法2:第二个Sort方法签名如下:
public virtual void Sort(DataGridViewColumn dataGridViewColumn, ListSortDirection direction)
使用后提示异常数据源不可排序。失败方法3:正解。声明一个List,将BindingList传入作为构造函数,对List进行排序再将元素添加回BindingList,代码如下:
private void SortReportsByDisplayOrder(ref BindingList<Report> reportList)
{
List<Report> list = new List<Report>(reportList);
ReportHelper.SortReportList(ref list);
reportList.Clear();
foreach (Metadata.Report rpt in list)
{
reportList.Add(rpt);
}
}
public static void SortReportList(ref List<Report> reportList)
{
reportList.Sort(delegate(Report x, Report y)
{
//First sort by category id, then display order, so report in same category gathered and sorted.
int result = x.CategoryID - y.CategoryID;
if (result == 0)
return x.DisplayOrder - y.DisplayOrder;
else
return result;
});
}
{
List<Report> list = new List<Report>(reportList);
ReportHelper.SortReportList(ref list);
reportList.Clear();
foreach (Metadata.Report rpt in list)
{
reportList.Add(rpt);
}
}
public static void SortReportList(ref List<Report> reportList)
{
reportList.Sort(delegate(Report x, Report y)
{
//First sort by category id, then display order, so report in same category gathered and sorted.
int result = x.CategoryID - y.CategoryID;
if (result == 0)
return x.DisplayOrder - y.DisplayOrder;
else
return result;
});
}
经测试,工作正常。
后记:
以上是1年多以前的代码了,现在看来方法3只是一个work around。BindingList其实是可以sort的:
((IBindingList)myBindingList).ApplySort( PropertyDescriptor prop, ListSortDirection direction);