VB表格控件总览

相关主题
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

VB表格控件总览:

在VB开发环境中,表格控件在界面开发元素中占有重要的地位。它不仅有外观整洁、

表达形式规范的优点,而且更重要的是它较高的信息表现率(就是相对于其他控件来说能

够表达更多的信息),随着信息时代的到来,它的应用将更加的广泛。

那么在VB平台下,如何操作这一功能强大的控件元素呢?事实上我们知道,VB平台

下面的表格控件是相当丰富的,总结下来提供了4种类型:Microsoft Data Bound grid Control

、Microsoft Datagrid Control、Microsoft Flexgrid Control、Microsoft Hierarchial Flexgrid Control. 这四种表格各有其特点,下面我们一一讨论。

1.Microsoft Data Bound grid Control

此控件主要用于数据绑定(可以不绑定,但是因为不提供对单个cell的控制支持,所以

实际上这样做是不经济的)。具体说来,就是数据源比较固定的情况下可以使用这种控件

具体使用方法是设定此控件的datasource属性,就可以不用编写任何代码就可以显示该

数据源所指向的记录数据。比如可以将datasource设置为一个data控件,而data控件又指向数

据库"成绩"的一个"语文"表,那么当程序运行时,它就自动显示此"语文"表的数据。

从上面的分析看得出来,这个控件虽然操作方便,但是它也有局限性,就是不能对显

示的数据进行灵活的控制操作,比如有些数据允许用户修改,有些数据却不允许用户修改

,而此控件却只能提供全部数据源的原子操作:即要么全部允许修改,要么就全部不允许

。还有另外此控件也不提供对单个单元格(cell)进行操作,所以提供不了更为个性化的界

面风格。

2.Microsoft Datagrid Control

此控件跟前面介绍的Data Bound grid Control控件很相似,也是主要进行绑定操作,而缺

点和Data Bound grid Control完全一样。但是它跟Data Bound grid Control不一样的是其数据源的驱动引擎只能是OLEDB形式的,不能是DAO,比如就可以使用ADO数据控件,不能使用DATA控件。而Data Bound grid Control却刚好和它相反,这一点在开发中一定要注意。

3.Microsoft Flexgrid Control与Microsoft Hierarchial Flexgrid Control.

这里重点介绍这两种控件,因为在实际开发中,这两种控件应用的场合更多一些,它

不仅能够反映数据,而且也能把数据的修改信息反映到数据库中去,所以弥补了上述两种

控件的不足。

如果数据不需要修改,那么可以进行绑定操作,其方法跟前面介绍的完全一样,就是

通过设置DataSource属性来完成数据的显示工作。但是实际开发中,需要对整个表格控件更

为灵活的显示控制。

在给出例程之前,有必要对这一控件进行比较详尽的认识:这种控件允许将文本或者

图象放置于每个单元格之中,控件的Row与Col属性允许用户在代码中指定当前行和列,当

然也可通过操作鼠标和键盘来改变这两个属性,而text属性指明当前单元格的文本。如果单

元格的文本太长而不能完全显示出来的话,可以通过将WordWrap属性设置为true来达到显

示的目的。下面将比较重要的属性小结如下:

DataSource---------用来指定需要绑定的数据源,比如data控件。

Cellpicture----------用来设定当前单元格的图象,便于显示该图象。此属性不能在设计时

使用。

Col,Row---------------设定当前列和当前行,注意它们均是从0开始的,如果同时设定

它们,可以指定当前的单元格。设计时也不能使用。

Cols,Rows---------------设置表格控件总的列数和行数。

Hwnd---------------表格句柄,可以结合Windows API对表格控件进行更高级的控制。

Text---------------指定当前的单元格的文本内容。

TextMatrix(i,j)-------此属性比较重要,它用来指定第I行和第j列所确定的单元格的文本内

容。它等价于下面的代码:

MSHFlexGrid1.Rows =i

MSHFlexGrid1.Cols =j

MSHFlexGrid1.Text =指定的字符串

WordWrap-------为ture时可以在当前单元格换行显示,否则如果要显示的字符的长度超

过列宽,那么就不能显示完全。

二.例程分析:

以上只是介绍了表格控件经常使用的属性,还有很多其他重要的属性这里限于篇幅就不一样讲解了,如果读者有兴趣的话可以参考MSDN上相关的内容的介绍,下面我这里提供一个例程来巩固前面的知识内容。

例程是使用Flexgrid 控件(由于Data Bound grid和Datagrid比较简单,所以这里就不再介绍了),如果大家手头上用的是MSHFlexgrid控件的话,只需要把名称换为MSFlexGrid1即可。该例程主要实现后台数据库的显示工作,其界面如下:

主要代码如下:

End Sub

Private Sub Form_Load()

'初始化数据

click = False

lastrow = 1

lastcol = 1

'初始化data控件,进行绑定显示的初始化

Data1.DatabaseName = App.Path & "\db1.mdb"

Data1.RecordSource = "成绩表"

'进行非绑定显示

Data1.Refresh

Data1.Recordset.MoveFirst

MSFlexGrid2.Rows = Data1.Database.Recordsets.Count + 1 '设置总行数MSFlexGrid2.Cols = Data1.Recordset.Fields.Count + 1 '设置总列数MSFlexGrid2.GridColor = vbBlue '网格颜色

MSFlexGrid2.ForeColor = vbRed '字体颜色

MSFlexGrid2.GridLines = 1 '设置网格线的属性

MSFlexGrid2.GridLineWidth = 2 '设置网格线的粗细程序,默认为1 MSFlexGrid2.ToolTipText = "非绑定显示" '设置工具提示文本MSFlexGrid2.BackColorSel = vbGreen '单元格被选中的颜色

Dim i%

Dim j%

'设置列头文本

For i = 1 To MSFlexGrid2.Cols - 1

MSFlexGrid2.TextMatrix(0, i) = Data1.Recordset.Fields(i - 1).Name Next i

'设置数据

For i = 1 To MSFlexGrid2.Rows - 1 '控制行

For j = 1 To MSFlexGrid2.Cols - 1 '控制列

MSFlexGrid2.TextMatrix(i, j) = Data1.Recordset.Fields(j - 1).Value

Next j

Data1.Recordset.MoveNext

Next i

'设置当前单元格的图象信息

MSFlexGrid2.Col = 0

MSFlexGrid2.Row = 2

Set MSFlexGrid2.CellPicture = LoadPicture(App.Path & "\cell.bmp") End Sub

'实现鼠标点击一个单元格的背景颜色的改变功能

Private Sub MSFlexGrid2_Click()

相关文档
最新文档