显示数据 VB表格控件总览与例程分析
2009-05-21 13:01
253 查看
作者:冯杰 来源:yesky 2008年6月23日
本文结合例程来对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即可。该例程主要实现后台数据库的显示工作,其界面如下:
Code
1 '实现编辑功能
2 Private Sub MSFlexGrid3_DblClick()
3 Text1.Visible = False
4 '如果初次双击,那么就执行如下代码
5 If firstclick = True Then
6 lastclickrow = MSFlexGrid3.Row
7 lastclickcol = MSFlexGrid3.Col
8 Text1.Text = MSFlexGrid3.TextMatrix(lastclickrow, lastclickcol)
9 End If
10 '将文本框放置到当前单元格处
11 Dim LeftOfText% '文本框的left属性
12 Dim TopOfText% '文本框的top属性
13 Dim selrow% '当前行
14 Dim selcol% '当前列
15 selrow = MSFlexGrid3.Row
16 selcol = MSFlexGrid3.Col
17 LeftOfText = Frame3.Left + MSFlexGrid3.Left + MSFlexGrid3.ColPos(selcol) + 45
18 TopOfText = Frame3.Top + MSFlexGrid3.Top + MSFlexGrid3.RowPos(selrow) + 45
19 Text1.Move LeftOfText, TopOfText, 930, 200
20 Text1.Visible = True
21 '如果不是初次双击,那么就执行如下代码
22 If firstclick = False Then
23 MSFlexGrid3.TextMatrix(lastclickrow, lastclickcol) = Text1.Text
24 lastclickrow = MSFlexGrid3.Row
25 lastclickcol = MSFlexGrid3.Col
26 End If
27 Text1.Text = MSFlexGrid3.TextMatrix(selrow, selcol)
28 '已经不是第一次进行双击操作
29 firstclick = False
30 End Sub
31
32
三、小结:
数据表格控件在实际运用用还有很多技巧,只有不断的在实际编程中积累经验才能达到灵活运用的功效。
本文结合例程来对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即可。该例程主要实现后台数据库的显示工作,其界面如下:
Code
1 '实现编辑功能
2 Private Sub MSFlexGrid3_DblClick()
3 Text1.Visible = False
4 '如果初次双击,那么就执行如下代码
5 If firstclick = True Then
6 lastclickrow = MSFlexGrid3.Row
7 lastclickcol = MSFlexGrid3.Col
8 Text1.Text = MSFlexGrid3.TextMatrix(lastclickrow, lastclickcol)
9 End If
10 '将文本框放置到当前单元格处
11 Dim LeftOfText% '文本框的left属性
12 Dim TopOfText% '文本框的top属性
13 Dim selrow% '当前行
14 Dim selcol% '当前列
15 selrow = MSFlexGrid3.Row
16 selcol = MSFlexGrid3.Col
17 LeftOfText = Frame3.Left + MSFlexGrid3.Left + MSFlexGrid3.ColPos(selcol) + 45
18 TopOfText = Frame3.Top + MSFlexGrid3.Top + MSFlexGrid3.RowPos(selrow) + 45
19 Text1.Move LeftOfText, TopOfText, 930, 200
20 Text1.Visible = True
21 '如果不是初次双击,那么就执行如下代码
22 If firstclick = False Then
23 MSFlexGrid3.TextMatrix(lastclickrow, lastclickcol) = Text1.Text
24 lastclickrow = MSFlexGrid3.Row
25 lastclickcol = MSFlexGrid3.Col
26 End If
27 Text1.Text = MSFlexGrid3.TextMatrix(selrow, selcol)
28 '已经不是第一次进行双击操作
29 firstclick = False
30 End Sub
31
32
三、小结:
数据表格控件在实际运用用还有很多技巧,只有不断的在实际编程中积累经验才能达到灵活运用的功效。
相关文章推荐
- C#如何读取Excel表格数据并显示到GridView控件
- ASP.NET基础教程-DataGrid表格控件-利用模板列中显示检索的数据
- ASP.NET的层次数据显示技术[数据控件嵌套循环]VB.NET
- jquery的表格控件jqGrid对自定义json数据的显示补丁
- 使用树形控件显示VB.NET层级数据
- 使用树形控件显示VB.NET层级数据
- VB.Net自己写的一个控件:ComboBox下拉列表中显示多列数据(可以绑定数据表)
- [VB.NET]100分求:如何从数据库取出数据并生成表格显示数据?
- VB.Net机房收费系统(三层)——用datagirdview 控件显示数据库数据
- .net 数据表格显示控件
- .net 数据表格显示控件介绍
- .net 数据表格显示控件介绍
- VB.Net机房收费系统(三层)——将datagirdview 控件数据导入Excel
- VB.NET 中DataGridView显示数据库中的数据
- GridView控件-01-[简单的数据显示]
- PyQt5调入数据库数据在表格中显示
- 用Repeater控件显示数据
- Control Study -> 主表和子表数据同时在绑定控件显示(示例代码下载)
- VB编写一个能显示百分比的自定义进度条控件
- 用Repeater控件显示数据