代码重构——之获得封装性DELPHI编码实例(3)

2008-04-10 02:57:26来源:互联网 阅读 ()

新老客户大回馈,云服务器低至5折

ClientDataSet.Filtered := True;

end

……

这样的代码通过硬码同样也实现了这个给数据集设置过滤器的功能,满足了需求,但是上面这段代码是不灵活的。如果数据集的字段很多就要求编码人员一个一个字段录入在Items中,而且在写case必须核对好顺序,不然设置的过滤器就是错误的也就很容易由开发人员引入BUG。用if语句时也一样维护一个大量的if同样是痛苦的,而且不支持需求变化,当用户要求改变数据集字段的中文显示名称时必须也要记住更改TComboBox. Items中的硬码数据,如果一旦忘记就会引入BUG

于是我在第一次重构中,尝试动态的加载TComboBox. Items中的数据,同时为了实现加载后用户选择时实现对照。我在这个查询FORM中加了一个 私有FFields: array[0..20, 0..2] of string; 字段来保存数据集中的字段信息数据。同时实现了一个加载数据的过程:

procedure TFrmSPARealStorageQuery.GetQueryFields;

var

i, iFieldsCount: Integer;

begin

iFieldsCount := 0;

with DBGride1.DataSource.DataSet do

begin

for i := 0 to Fields.Count - 1 do

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:NeHe的opengl教程delphi版(7)----滤波

下一篇:用 Delphi 实现报表的横向分组打印