提供3000多款全球软件/控件产品
针对软件研发的各个阶段提供专业培训与技术咨询
根据客户需求提供定制化的软件开发服务
全球知名设计软件,显著提升设计质量
打造以经营为中心,实现生产过程透明化管理
帮助企业合理产能分配,提高资源利用率
快速打造数字化生产线,实现全流程追溯
生产过程精准追溯,满足企业合规要求
以六西格玛为理论基础,实现产品质量全数字化管理
通过大屏电子看板,实现车间透明化管理
对设备进行全生命周期管理,提高设备综合利用率
实现设备数据的实时采集与监控
利用数字化技术提升油气勘探的效率和成功率
钻井计划优化、实时监控和风险评估
提供业务洞察与决策支持实现数据驱动决策
翻译|使用教程|编辑:龚雪|2025-10-10 10:40:13.510|阅读 64 次
概述:本教程主要为大家介绍如何使用DevExpress WinForms数据网格控件自定义排序和非排序列,欢迎下载最新版组件体验!
#慧都22周年庆大促·界面/图表报表/文档/IDE/IOT/测试等千款热门软控件火热促销中>>
相关链接:
DevExpress WinForms拥有180+组件和UI库,能为Windows Forms平台创建具有影响力的业务解决方案。DevExpress WinForms能完美构建流畅、美观且易于使用的应用程序,无论是Office风格的界面,还是分析处理大批量的业务数据,它都能轻松胜任!
在本教程中,您将学习如何实现自定义排序算法来对Birth Date列的值进行排序,而不考虑日期的年份部分,从而获得组织中所有生日的正确排序列表,同时还将学习针对包含不可排序数据(如图像)的列启用排序的技术。
获取DevExpress WinForms v25.1正式版下载
DevExpress技术交流群11:749942875 欢迎一起进群讨论
如果单击Birth Date列标题,默认算法将首先考虑年、月、天对日期进行排序。如您所见,该列表显示1月份的生日,然后是5月份的生日,然后又是1月份的生日,因为它们是按年份排序的。
本教程实现了一个自定义排序逻辑,该逻辑将忽略年份部分,并给出仅按月份和日期排序的生日列表。
首先,将列的GridColumn.SortMode属性设置为ColumnSortMode.Custom。
之后,选择网格视图并处理它的ColumnView.CustomColumnSort事件。
要处理的列由事件的CustomColumnSortEventArgs.Column参数指定,事件处理程序比较使用CustomColumnSortEventArgs.Value1和CustomColumnSortEventArgs.Value2参数指定的两个值,自定义比较的结果被设置为CustomColumnSortEventArgs.Result参数。这个例子比较了生日月份,如果第一个月的数字大于第二个月的数字,则Result参数设置为1,如果第一个月的数字小于第二个月的数字,则将Result参数设置为-1。如果值相等,比较天数。
事件的CustomColumnSortEventArgs.Handled参数被设置为true,以防止在事件执行后调用默认的比较机制。
C#
private void gridView_CustomColumnSort(object sender, DevExpress.XtraGrid.Views.Base.CustomColumnSortEventArgs e) {
if (e.Column.FieldName == "BirthDate") {
e.Handled = true;
int month1 = Convert.ToDateTime(e.Value1).Month;
int month2 = Convert.ToDateTime(e.Value2).Month;
if (month1 > month2)
e.Result = 1;
else
if (month1 < month2)
e.Result = -1;
else e.Result = System.Collections.Comparer.Default.Compare(Convert.ToDateTime(e.Value1).Day, Convert.ToDateTime(e.Value2).Day);
}
}
运行应用程序并单击Birth Date列标题,单元格值现在基于月份和日期比较进行排序,排序顺序忽略年份。
GridControl 可以包含显示不可排序数据(如图像)的列。
Photo列使用PictureEdit就地编辑器显示图像,单击其标题时不会发生任何事情。但是,您也可以为此列启用数据排序。
首先,选择Photo列,展开它的GridColumn.OptionsColumn属性,并将OptionsColumn.AllowSort设置为true。然后,将其GridColumn.SortMode属性设置为ColumnSortMode.Custom。
将以下代码添加到ColumnView.CustomColumnSort事件处理程序中。当Photo列的数据排序时,数据实际上将根据First Name列排序。在数据源级别使用事件的CustomColumnSortEventArgs.ListSourceRowIndex1和CustomColumnSortEventArgs.ListSourceRowIndex2参数访问列值,CustomColumnSortEventArgs.Handled参数被设置为true,表示已经处理了比较操作。
C#
private void gridView_CustomColumnSort(object sender, DevExpress.XtraGrid.Views.Base.CustomColumnSortEve
// ...
if (e.Column.FieldName == "Photo") {
e.Handled = true;
DataRowView dr1 = (gridView.DataSource as BindingSource)[e.ListSourceRowIndex1] as DataRowView;
DataRowView dr2 = (gridView.DataSource as BindingSource)[e.ListSourceRowIndex2] as DataRowView;
e.Result = System.Collections.Comparer.Default.Compare(dr1["FirstName"], dr2["FirstName"]);
}
}
运行应用程序并单击Photo列标题,网格数据现在根据FirstName列中的值排序。
更多DevExpress线上公开课、中文教程资讯请上中文网获取
慧都是⼀家⾏业数字化解决⽅案公司,专注于软件、⽯油与⼯业领域,以深⼊的业务理解和⾏业经验,帮助企业实现智能化转型与持续竞争优势。
慧都科技是DevExpress的中国区的合作伙伴,DevExpress作为用户界面领域的优秀产品,帮助企业高效构建权限管理、数据可视化(如网格/图表/仪表盘)、跨平台系统(WinForms/ASP.NET/.NET MAUI)及行业定制解决方案,加速开发并强化交互体验。
本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@evget.com
文章转载自:慧都网



Parasoft C++test 是一款用于自动化执行C/C++代码测试的集成解决方案,它支持静态分析、单元测试以及运行时错误检测等多种最佳实践,帮助开发团队提升软件质量与开发效率。
在嵌入式软件开发中,集成专业的自动化测试工具对于提升代码质量和验证效率至关重要。Parasoft C/C++test作为一款支持多种编译环境的测试平台,能够通过构建数据文件(BDF)方式无缝导入第三方工程,实现对嵌入式项目的静态分析、单元测试及覆盖率验证。
本文主要介绍如何在MVVM应用程序中使用虚拟源,欢迎下载最新版组件体验!
Parasoft C/C++test作为一款专业的自动化测试工具,广泛用于C/C++语言的静态分析、单元测试及覆盖率验证。然而,在实际测试过程中,抽象类因包含纯虚函数而无法直接实例化,导致其成员函数的自动化测试面临挑战。下面将会深入探讨如何在C++test环境中通过手动创建与适配测试用例的方式,实现对抽象类中非虚成员函数的有效测试。
相关产品
为Windows Forms平台创建具有影响力的业务解决方案,高性价比WinForms界面控件套包。
DevExpress Universal Subscription优秀的界面控件开发包,帮助企业构建卓越应用!
DevExpress DXperience Subscription高性价比的企业级.NET用户界面套包,助力企业创建卓越应用!
最新文章 MORE
相关文章 MORE
服务电话
重庆/ 023-68661681
华东/ 13452821722
华南/ 18100878085
华北/ 17347785263
客户支持
技术支持咨询服务
服务热线:400-700-1020
邮箱:sales@evget.com
关注我们
地址 : 重庆市九龙坡区火炬大道69号6幢
慧都科技 版权所有 Copyright 2003-
2025 渝ICP备12000582号-13 
渝公网安备
50010702500608号
首页