休息在家,难得有敲代码的雅兴,随手敲个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;

好吧,写出来就是让大家指正的。

源码地址:https://github.com/NanQi/demo/tree/master/FilterDemo


blog comments powered by Disqus

Published

2012-12-05

Tags