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);

即可

目录
相关文章
|
关系型数据库 MySQL Linux
在Linux中,如何检查某项服务是否在运行?
在Linux中,如何检查某项服务是否在运行?
|
11月前
|
SQL 关系型数据库 MySQL
MySQL中的 where 1=1会不会影响性能?看完官方文档就悟了!
本文探讨了在Mybatis中使用`where 1=1`进行动态SQL拼接是否会影响性能。通过MySQL官方资料和实际测试表明,`where 1=1`在MySQL 5.7及以上版本中会被优化器优化,因此对性能影响不大。文中详细对比了`where 1=1`与`&lt;where&gt;`标签的使用方法,并建议根据MySQL版本和团队需求选择合适的方式。最后,推荐查找官方资料以确保技术路线正确。
236 4
|
存储 数据库
如何在数据库中存储小数:FLOAT、DECIMAL还是BIGINT?
【8月更文挑战第7天】在数据库中存储小数时,需谨慎选择数据类型:FLOAT、DECIMAL 或 BIGINT。FLOAT 存储空间小,适于非关键性小数如温度;但精度有限,可能产生误差。DECIMAL 能精确表示小数,适合货币金额等需要高度准确性的场景,不过占用空间较大。BIGINT 用于整数,若存储小数需额外转换处理。根据精度需求及应用场景选择合适类型至关重要。
606 2
|
存储 缓存 开发工具
Transformers 4.37 中文文档(十三)(4)
Transformers 4.37 中文文档(十三)
587 1
|
Android开发
【亲测,安卓版】快速将网页网址打包成安卓app,一键将网页打包成app,免安装纯绿色版本,快速将网页网址打包成安卓apk
【亲测,安卓版】快速将网页网址打包成安卓app,一键将网页打包成app,免安装纯绿色版本,快速将网页网址打包成安卓apk
869 0
C# Dev解决gridview1_SelectionChanged和gridview1_RowCellClick事件触发两次等问题
C# Dev解决gridview1_SelectionChanged和gridview1_RowCellClick事件触发两次等问题
C# Dev解决gridview1_SelectionChanged和gridview1_RowCellClick事件触发两次等问题
|
机器学习/深度学习 存储 编解码
了解FastSam:一个通用分割模型(草记)(1)
一、FastSam下载与体验 1 问题记录 似乎从网页上下载压缩包,会比使用git clone要方便很多。 1 CLIP是什么?
775 0
|
缓存 C# 块存储
使用双缓冲技术解决winform窗体控件卡顿(dataGridView加载数据缓慢)
使用双缓冲技术解决winform窗体控件卡顿(dataGridView加载数据缓慢)
2347 0
|
前端开发 小程序 开发者
微信小程序授权登录(含获取基本信息及绑定的手机号)
微信小程序授权登录(含获取基本信息及绑定的手机号)
微信小程序授权登录(含获取基本信息及绑定的手机号)