VB表格控件总览与例程分析[转载]
上一篇 / 下一篇 2007-03-06 09:37:31 / 天气: 晴朗 / 心情: 平静 / 个人分类:vb
z5J Wr!K2vH!L0一.表格控件总览: 这四种表格各有其特点,下面我们一一讨论。 Bl&ib2a9Jw4Y051Testing软件测试网G [5h#^4L&E,A 1. Microsoft Data Bound grid Control51Testing软件测试网{ U"OY3h'{!Ju!xJg ,eb%G,nB-Ow3]9s0 此控件主要用于数据绑定(可以不绑定,但是因为不提供对单个cell的控制支持,所以实际上这样做是不经济的)。具体说来,就是数据源比较固定的情况下可以使用这种控件。51Testing软件测试网qw E Q3EP/xyJ3SI(i Z+@;v k:k0 具体使用方法是设定此控件的datasource属性,就可以不用编写任何代码就可以显示该数据源所指向的记录数据。比如可以将datasource设置为一个data控件,而data控件又指向数据库"成绩"的 一个"语文"表,那么当程序运行时,它就自动显示此"语文"表的数据。51Testing软件测试网J1c&L8OMV ?;@F pW d(u|0 从上面的分析看得出来,这个控件虽然操作方便,但是它也有局限性,就是不能对显示的数据进行灵活的控制操作,比如有些数据允许用户修改,有些数据却不允许用户修改,而此控件却只能提供全部数据源的原子操作:即要么全部允许修改,要么就全部不允许。还有另外此控件也不提供对单个单元格(cell)进行操作,所以提供不了更为个性化的界面风格。51Testing软件测试网-~ g5v;M\E'k8KK 1r Qne*k5zu0 2. Microsoft Datagrid Control51Testing软件测试网"A#@h jI)C.l+t'If)G 51Testing软件测试网)U"Id!j?$ni$D7|6p 此控件跟前面介绍的Data Bound grid Control控件很相似,也是主要进行绑定操作,而缺点和Data Bound grid Control完全一样。但是它跟Data Bound grid Control不一样的是其数据源的驱动引擎只能是OLEDB形式的,不能是DAO,比如就可以使用ADO数据控件,不能使用DATA控件。而Data Bound grid Control却刚好和它相反,这一点在开发中一定要注意。 (la&na$wg%j"h*rpX0 Ou\&iDe^0 3. Microsoft Flexgrid Control与Microsoft Hierarchial Flexgrid Control. ;Tn$j+o3AM5Gk051Testing软件测试网'jdM"J(p.Y(t 这里重点介绍这两种控件,因为在实际开发中,这两种控件应用的场合更多一些,它不仅能够反映数据,而且也能把数据的修改信息反映到数据库中去,所以弥补了上述两种控件的不足。51Testing软件测试网OFE?c1ZO1PX :ZLF/m-j&Eo+l0 如果数据不需要修改,那么可以进行绑定操作,其方法跟前面介绍的完全一样,就是通过设置DataSource属性来完成数据的显示工作。但是实际开发中,需要对整个表格控件更为灵活的显示控制。51Testing软件测试网cU"Dx/pY "R(B%YBJQ+y1i0 在给出例程之前,有必要对这一控件进行比较详尽的认识:这种控件允许将文本或者图象放置于每个单元格之中,控件的Row与Col属性允许用户在代码中指定当前行和列,当然也可通过操作鼠标和键盘来改变这两个属性,而text属性指明当前单元格的文本。如果单元格的文本太长而不能完全显示出来的话,可以通过将WordWrap属性设置为true来达到显示的目的。下面将比较重要的属性小结如下: 4g+L'c9f:NDt3Vc051Testing软件测试网j+MFG1jE DataSource---------用来指定需要绑定的数据源,比如data控件。51Testing软件测试网3W4Jm w n&[ RX "l5kas&c4E5TnA[0 Cellpicture----------用来设定当前单元格的图象,便于显示该图象。此属性不能在设计时使用。 *LRK_0DV*k s0 "c&HM4K4v5A!_JG0 Col,Row---------------设定当前列和当前行,注意它们均是从0开始的,如果同时设定它们,可以指定当前的单元格。设计时也不能使用。51Testing软件测试网6x$I0H-J&^jo ;?9LpLr-q U F0 Cols,Rows---------------设置表格控件总的列数和行数。51Testing软件测试网U B5Xyk,W&o 51Testing软件测试网a-nL"C1l{ tK0i Hwnd---------------表格句柄,可以结合Windows API对表格控件进行更高级的控制。 on py2H @[.wp0 M~n)^OE0 Text---------------指定当前的单元格的文本内容。 h~7t ]@:x1bE0 @'Y-i+B2\,Ly0 TextMatrix(i,j)-------此属性比较重要,它用来指定第I行和第j列所确定的单元格的文本内容。它等价于下面的代码: Ij3kwH Dd^ D051Testing软件测试网 Uy1],qf~5] MSHFlexGrid1.Rows =i 3X u2y-R,m0MSHFlexGrid1.Cols =j51Testing软件测试网}2o]lC}2BiF^i MSHFlexGrid1.Text =指定的字符串 p!QxvWr4Jq6S051Testing软件测试网{D0G[#IL O WordWrap-------为ture时可以在当前单元格换行显示,否则如果要显示的字符的长度超过列宽,那么就不能显示完全。51Testing软件测试网+_!I'n2m|@q9M+p 二.例程分析:51Testing软件测试网$Zt$zlnY 7Af.@er}G*?!|0 以上只是介绍了表格控件经常使用的属性,还有很多其他重要的属性这里限于篇幅就不一样讲解了,如果读者有兴趣的话可以参考MSDN上相关的内容的介绍,下面我这里提供一个例程来巩固前面的知识内容。 c K(l7LZ}(_0例程是使用Flexgrid 控件(由于Data Bound grid和Datagrid比较简单,所以这里就不再介绍了),如果大家手头上用的是MSHFlexgrid控件的话,只需要把名称换为MSFlexGrid1即可。该例程主要实现后台数据库的显示工作,其界面如下: 51Testing软件测试网0e;i{#D wqo 51Testing软件测试网 nJl?0yfM51Testing软件测试网+}"s4[0ut Dim lastrow% '最后一次鼠标点击的行 |