Winform中DataGridView绑定IList数据源后的排序

简介: 首先,实现ICompare接口 public class ObjectPropertyCompare : IComparer {private PropertyDescriptor property;private ListSortDirection direction;// 构造函数 ...

首先,实现ICompare接口

 
 
public class ObjectPropertyCompare < T > : IComparer < T > {
private PropertyDescriptor property;
private ListSortDirection direction;

// 构造函数
public ObjectPropertyCompare(PropertyDescriptor property, ListSortDirection direction) {
this .property = property;
this .direction = direction;
}

// 实现IComparer中方法
public int Compare(T x, T y) {
object xValue = x.GetType().GetProperty(property.Name).GetValue(x, null );
object yValue = y.GetType().GetProperty(property.Name).GetValue(y, null );

int returnValue;

if (xValue is IComparable) {
returnValue
= ((IComparable)xValue).CompareTo(yValue);
}
else if (xValue.Equals(yValue)) {
returnValue
= 0 ;
}
else {
returnValue
= xValue.ToString().CompareTo(yValue.ToString());
}

if (direction == ListSortDirection.Ascending) {
return returnValue;
}
else {
return returnValue * - 1 ;
}
}
}

然后创建自定义的类,实现IBindingList接口,为方便起见,这里直接继承BindingList类

 
 
/// <summary>
/// 自定义绑定列表类
/// </summary>
/// <typeparam name="T"> 列表对象类型 </typeparam>
public class BindingCollection < T > : BindingList < T > {
private bool isSorted;
private PropertyDescriptor sortProperty;
private ListSortDirection sortDirection;

/// <summary>
/// 构造函数
/// </summary>
public BindingCollection()
:
base () {
}

/// <summary>
/// 构造函数
/// </summary>
/// <param name="list"> IList类型的列表对象 </param>
public BindingCollection(IList < T > list)
:
base (list) {
}

/// <summary>
/// 自定义排序操作
/// </summary>
/// <param name="property"></param>
/// <param name="direction"></param>
protected override void ApplySortCore(PropertyDescriptor property, ListSortDirection direction) {
List
< T > items = this .Items as List < T > ;

if (items != null ) {
ObjectPropertyCompare
< T > pc = new ObjectPropertyCompare < T > (property, direction);
items.Sort(pc);
isSorted
= true ;
}
else {
isSorted
= false ;
}

sortProperty
= property;
sortDirection
= direction;

this .OnListChanged( new ListChangedEventArgs(ListChangedType.Reset, - 1 ));
}

/// <summary>
/// 获取一个值,指示列表是否已排序
/// </summary>
protected override bool IsSortedCore {
get {
return isSorted;
}
}

/// <summary>
/// 获取一个值,指示列表是否支持排序
/// </summary>
protected override bool SupportsSortingCore {
get {
return true ;
}
}

/// <summary>
/// 获取一个只,指定类别排序方向
/// </summary>
protected override ListSortDirection SortDirectionCore {
get {
return sortDirection;
}
}

/// <summary>
/// 获取排序属性说明符
/// </summary>
protected override PropertyDescriptor SortPropertyCore {
get {
return sortProperty;
}
}

/// <summary>
/// 移除默认实现的排序
/// </summary>
protected override void RemoveSortCore() {
isSorted
= false ;
this .OnListChanged( new ListChangedEventArgs(ListChangedType.Reset, - 1 ));
}

创建BindingCollection后即可直接应用:

原来的方式是:

IList<object> list = new List<object>();

...

dataGridView.DataSource = list;

现在只需更改最后一句为:

dataGridView.DataSource = new BindingCollection<object>(list);

即可

目录
相关文章
|
C# 数据库
C# DataGridView用法(—)代码绑定数据源
C# DataGridView用法(—)代码绑定数据源
455 1
|
数据库 C# 数据库管理
C#:Winfrom 实现DataGridView 自定义分页
今天给大家分享Winform实现DataGridView 自定义分页的案例,感兴趣的朋友可以一起来学习一下。 采用技术:C\#+Winform+Dapper+SQLite。
C#:Winfrom 实现DataGridView 自定义分页
|
SQL 存储 Go
WinForm DataGridView分页功能
WinForm 里面的DataGridView不像WebForm里面的GridView那样有自带的分页功能,需要自己写代码来实现分页,效果如下图: 分页控件   .CS: 1 using System; 2 using System.
1420 0
C#编程-70:dataGridView绑定数据源
C#编程-70:dataGridView绑定数据源
247 0
c#Winform修改datatable的列的操作和一些combox绑定实体类,dataGridview的注意点 弹出确认框 弹出的winform出现的位置 load
ds是DataSet 是Datatable的集合 ds.Tables[0]是得到第一张表 然后就是对dt的操作 将Fill_ID列名修改为 “序号” 依次修改列名 combox绑定list 显示combox上的值是用cmb_name 但是 在窗体加载的时候 cmb_name是 它本身的类型名字 而不是空 只有当它上面绑定有真正的值后才会显示。
1369 0