zoukankan      html  css  js  c++  java
  • 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;
                        }
    );
            }


              经测试,工作正常。


    后记

    以上是1年多以前的代码了,现在看来方法3只是一个work around。BindingList其实是可以sort的:

    ((IBindingList)myBindingList).ApplySortPropertyDescriptor prop, ListSortDirection direction);


     

  • 相关阅读:
    Xlua侧如何接受CSharp侧的可变参数
    C# 中如何精确地测量一段逻辑的执行时间
    C#中设计一个 ListPool 的方案
    unity中获取设备的信息
    Oracle-游标-取钱-存钱-转账
    Oracle 存储过程与java调用
    PL/SQL loop,while.for循环
    PL/SQL if case when
    PL/SQL %type %rowtype
    Oracle PLSQL入门
  • 原文地址:https://www.cnblogs.com/k330/p/1187255.html
Copyright © 2011-2022 走看看