浅谈VB编程中网格控件的选用及使用方法_第1页
浅谈VB编程中网格控件的选用及使用方法_第2页
浅谈VB编程中网格控件的选用及使用方法_第3页
已阅读5页,还剩2页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

浅谈VB编程中网格控件的选用及使用方法

随着基于构件开发(Component-BasedDevelopment)技术的发展,供开发者使用的软件构件越来越多,单就VB中可使用的网格类控件也有许多种。网格类控件常用在数据库管理系统的开发中,用来直观地显示表或视图的二维关系,在对数据的操作上,有些控件也提供了很多便捷的方法。同样是完成这些显示和操作数据的功能,面对各式各样的控件,选择那种来达到目的,成了软件开发者必须考虑的新问题。唯有选择了一个好的控件,才能提高开发效率,增强软件的功能,达到事半功倍的效果。下面,本人根据自己长期以来积累的实际经验,总结出以下几点网格控件的选用应考虑的方面摘要:第一,要考虑控件的实际功能。功能强、接口多的控件可以增强应用软件的质量,也可减少编程工作量,当然,这要结合应用需求来定,并不是功能越多越好。提供的功能多了,控件本身就很大,占好几兆空间,增加了程序的冗余代码。另外,一些功能闲置,灵活性太强也可能导致最终用户不易把握使用。第二,控件的稳定性要强。作为应用程序的基石,不应选用那些控件本身轻易出错,补丁(patch)太多的版本。第三,控件的易用性要高。选用那些属性配置合理,事件触发机制明晰流畅,易于设计和使用,项目组中的程序员都轻易接受把握的控件。以下简要介绍几种网格类控件的特征,以供选用。Grid控件摘要:Grid控件可显示简单的二维表格,不用和数据库直接连接,具有滚动条、行头、列头等特性,运行时可用鼠标调整行列的宽度,可用于浏览数据,若想对数据进行编辑,需结合TextBox控件,或采取其他变通方法。下面所示画面即为日本东京社会调查探究所开发的《要员管理系统》中硬件管理部分的画面。画面中的下部即为Grid控件,定义其名称为GrdHardComp。使用时,要首先在下图所示的属性窗口中定义其行列数,控制条格式,字体大小,填充格式,鼠标模式等特性。然后,可以动态的划分其间距摘要:GrdHardComp.ColWidth(0)=GrdHardComp.Width*1/6GrdHardComp.ColWidth(1)=GrdHardComp.Width*5/24GrdHardComp.ColWidth(2)=GrdHardComp.Width*1/6GrdHardComp.ColWidth(3)=GrdHardComp.Width*1/6GrdHardComp.ColWidth(4)=GrdHardComp.Width*3/24GrdHardComp.ColWidth(5)=GrdHardComp.Width*1/6GrdHardComp.ColWidth(6)=GrdHardComp.Width*1/6PrivateHards()AsM_Hard定义其标题摘要:GrdHardComp.Row=0'GrdHardComp.Col=0GrdHardComp.FixedAlignment(GrdHardComp.Col)=2GrdHardComp.Text="构成番号"GrdHardComp.Col=1GrdHardComp.FixedAlignment(GrdHardComp.Col)=2GrdHardComp.Text="构成机器区分"①……在数据向Grid中写入或取出时,为了便于大量的数据同时,简便地写入和修改,可以定义一个类型。如下摘要:TypeM_HardNumberAsStringOrderNumAsStringMachKindAsStringMachKindNameAsString……EndType(其中Number等均为要输入的图示条目)PrivateHards()AsM_HardHards(),此时就作为数据的传输变量,进行Grid和TextBox之间的数据传输。数据向类内写入摘要:IfHardComp.RecordCount>0ThenHardComp.MoveFirstDoUntilHardComp.EOFReDimPreserveHards(H%)//H%为记数变量。Hards(H%).OrderNum=HardComp![OrderNum//输入编号Hards(H%).MachKind=HardComp![MachKind//种类Hards(H%).MachKindName=HardComp![MachKindName//分类名Hards(H%).MachName=HardComp![MachName//名称……loopHardComp.MoveFirst类内数据向Grid内写入摘要:GrdHardComp.Row=H%+1//记录数统计GrdHardComp.Col=0GrdHardComp.Text=""%26Hards(H%).OrderNumGrdHardComp.Col=1GrdHardComp.Text=""%26Hards(H%).MachKindGrdHardComp.Col=2GrdHardComp.Text=""%26Hards(H%).MachKindNameGrdHardComp.Col=3GrdHardComp.Text=""%26Hards(H%).MachNameGrdHardComp.Col=4……GrdHardComp.Text=""%26Hards(H%).HardLastDateGrdHardComp.Rows=GrdHardComp.Rows+1//行数加1HardComp.MoveNextH%=H%+1当然,假如使数据真正写入数据库,还需进行数据库的读写操作。Grid只是提供了一个预览的功能,便于数据的修改。由以上Grid的特征及其使用方法可以看出,在需要对数据库进行大量数据的操作时,为了减少对数据库的直接操作,提高数据库的平安性,使用Grid控件,还是有很大方便的。Grid是VB在早期版本中就带有的控件,使用简便,稳定性好,在早期的VB开发过程中,使用尤其广泛。但现在和其它控件比较起来功能有些不足。DBGrid控件摘要:DBGrid是专用来操作数据库的网格控件,可以绑定到Data控件,几乎不用写代码就可方便地对数据进行显示,增加、删除或修改记录,DBGrid具有OnAddNew、BeforeDelete等事件,可在增加新记录或删除修改时对数据进行有效性检验,来实现事务处理功能。DBGrid也可以在设计时编辑网格格式,指定显示字段等,由于它提供了Column、Split、SelBookmarks等对象,更增强了显示和操作数据的能力。下面是笔者所参和开发的东京社会调查探究所的项目--《健康诊断系统》的一个实例。图中的Data4控件把数据库和DBGrid直接连起来,DBGrid的题目,项目设置可以在属性窗口里直接做到。在使用时,要注重新数据是先更新数据库,然后才回写到DBGrid里。Data4.Recordset![记号=DBGrid.Columns(0).CellValue(DBGrid.GetBookmark(0))//第一列Data4.Recordset[番号=DBGrid.Columns(1).CellValue(DBGrid.GetBookmark(0))//第二列Data4.Recordset![氏名=DBGrid.Columns(2).CellValue(DBGrid.GetBookmark(0))//第三列Data4.Recordset.UpdateData4.Refresh//数据库更新DBGrid.Refresh//DBGrid刷新假如动态的对DBGrid中的某个栏目进行增减,可以用如下方法摘要:i=1//总显示列数记数Data4.MoveFirstDoUntilData4.EOFDBGrid1.Columns(i).Width=1600//定义宽度DBGrid1.Columns(i).Caption="年龄"//标题DBGrid1.Columns(i).DataField="%26实际数据域%26"DBGrid1.Columns(i).Visible=True//可见性DBGrid1.Columns(i).Alignment=1//DBGrid控件列中的值的对齐方式Data4.MoveNexti=i+1Ifi>8ThenExitDo//列数最大为8Loop由于具有良好的可靠性,灵活性和直观性,所以DBGrid控件现在被广泛使用。但不足之处在于DBGrid,和直接操作数据库,对数据库的正确性有一定的威胁。改进方法是,在修改数据库时,加入提示信息。TrueDBGrid摘要:DBGrid是Apex软件公司为微软开发的,而Apex的TrueDBGrid控件也具有较强的数据显示及处理功能,因和DBGrid同出一宗,所以两者有很多相同点。在基本功能上,DBGrid的增,减等操作方法可直接用于TrueDBGrid,在这里就不再赘述。但在DBGrid的基础上,TrueDBGrid可以直接嵌入ListBox、Image位图、单选框等控件(如图所示),使软件的界面更加美观,实用。SSDBGrid控件摘要:SSDBGrid来自Sheridan软件系统公司(http摘要://),和Sheridan的其它控件一样,以漂亮的三维界面见长,SSDBGrid还可和其它数据库控件如SSDBData、SSDBCombo等有机结合,为用户处理数据提供方便,它有几百个属性、方法等接口,为界面的润色提供了很大的选择余地。另外SSDBGrid还具有虚拟数据管理(virtualdatamanagement)技术,在内存中只存贮需显示在界面上的记录,这样在处理大量数据时不致耗费系统资源而影响运行速度。SSDBGrid的缺点只是在有些版本中输入汉字时会出现一些乱码,但显示汉字的效果很不错。MSFlexGrid控件摘要:

MSFlexGrid和vsFlexArray在显示数据方面有很多独到之处,在运行中可通过拖放来交换各列的位置,动态地对数据进行排序、分组合并等。vsFlexArray控件是VideoSoft公司的产品,MSFlexGrid的部分技术也来自此公司。vaSpread控件摘要:vaSpread控件在处理数据方面有着更大的灵活性,它支持数据绑定,虚拟数据管理等技术,而且具备了电子表格的功能,编辑中可以使用剪贴板来剪切或复制单元格区域的数据,单元格中也可以加入公式,借助Spread的计算引擎(Spread'sCalcEngine)对数据进行分析计算。SpreadDesigner还可方便地设计表格的格式,在单元格中加入按钮、图片、组合框等,自己设计的表格格式还能作为模板和数据分开来保存。若想得到简单的报表,vaSpread的打印功能可直接把界面和数据打印出来,而不需通过专门的报表

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

最新文档

评论

0/150

提交评论