WinForm下一个筛选的demo(希望大家指正)

神棍 2012-12-10 08:08:45
休息在家,难得有敲代码的雅兴,随手敲个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.github.com
...全文
107 回复 打赏 收藏 转发到动态 举报
写回复
用AI写文章
回复
切换为时间正序
请发表友善的回复…
发表回复

110,549

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • Web++
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧