WinForm下一个筛选的demo(希望大家指正)
休息在家,难得有敲代码的雅兴,随手敲个demo,给大家看看。
里面部分实现对于新手估计有所帮助,对于高手呢,就请大家给我指错吧。本人照单全收。
demo主要实现了两个功能。
- 高级查找(FrmSift)
- 列表筛选(UCFilter)
关于sift和filter两个词这里就不做争论了。
先看我画的demo界面:
高级查找
高级查找针对于查找选项过多的情况下使用,做为一个通用的查找功能出现在软件项目中。
高级查找使用时基本只需传入当前的DataGridView实例,生成需要的Where条件。
在demo中,高级查找实现了基本的通用功能,可以在多个数据列表中使用。
高级查找根据所给的DataGridView生成列选项(左边的选择项),对于某些不想显示的列可以隐藏(代码中我隐藏了第一列GUID),对于特殊的情况,可以传入一个SiftItem数组。
数据类型现在只做了三种判断,而且判断方式让人吐血:
switch (type.ToString()) { case "System.Int16": case "System.Int32": case "System.Int64": case "System.Single": case "System.Double": case "System.Decimal": siftType = SiftTypeEnum.Money; break; case "System.DateTime": siftType = SiftTypeEnum.Date; break; default: siftType = SiftTypeEnum.Text; break; }
对于数字类型和日期类型,给予两个条件共同完成——从XXX至XXX
,所以在处理上也费了点功夫。比如说删除其中一个,另一个也要删除等情况。
高级查找现在只做了AND条件,没有强大的组合方式。
值得一提的是在处理日期类型时不能得到多数据库的支持,这里由于只是模拟数据,使用DataTable的Select去模拟查找功能,日期类型没问题。但是如果是MSSQL可能会出错,如果更甚者在数据库中使用varchar保存日期类型,这里处理就更加麻烦。(比如本人在项目中就对Oracle的此类现象进行了处理)
这里对于时间段做了一些功夫,其实都是有一次项目中需要,这里也就没删,保留了下来,希望对大家有用。
列表选择
列表选择实现的最大一个功能就是可以筛选。
对于筛选后的列表,不会改变已经选择的状态。
其实很简单,不止保存数据源,还保存了对于每个数据的选择状态。
在列表查找中,对于上方全选的处理实在让我费了不少功夫。
主要是很多方面都要我去判断全选状态。
ListCheckBox的ItemCheck事件和全选的CheckStateChanged事件几乎让我弄的惨不忍睹,加了减了,减了加了,如下类似的代码我调用了不知道多少次。
this.chbxAll.CheckStateChanged -= this.chbxAll_CheckStateChanged; //do something this.chbxAll.CheckStateChanged += this.chbxAll_CheckStateChanged;
好吧,写出来就是让大家指正的。
最后,源码:下载
欢迎来我的博客:nanqi.info
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?