msflexgrid和 mshflexgrid区别与联系

来源:互联网 发布:汽车电子控制软件 编辑:程序博客网 时间:2024/05/06 10:23

做几房收费系统,在显示查询数据结果的时候,多次的使用到了flexgrid控件.为我们的显示提供了很好的方便.

在说这个控件之前,首先说一下与他类似的一个控件,mshflexgrid.

他们两个的区别

 

简单地说,MSFlexGridMSHFlexGrid之间的区别,主要是后者支持ADO的层次显示。如果你不使用ADO,可以考虑MSFlexGrid,否则建议使用MSHFlexGrid

这两个控件的详解:


 

 

MSFlexGrid 控件

Microsoft FlexGrid (MSFlexGrid) 控件可以显示网格数据,也可以对其进行操作。它提供了高度灵活的网格排序、合并和格式设置功能,网格中可以包含字符串和图片。如果将它绑定到一个 Data 控件上,那么 MSFlexGrid 显示的将是只读的数据。

语法

MSFlexGrid

说明

文本和图片可以同时或者单独放在 MSFlexGrid 的任何一个单元格中。Row Col 属性指定了当前的 MSFlexGrid 单元格。程序员可以在代码中改变当前单元格,用户可以在运行时使用鼠标或者箭头键改变它。Text 属性提供了当前单元格内容的参考信息。

 

如果单元格中的文本过长,无法全部显示在单元格的一行中,而且 WordWrap 属性被设置为 True,那么文本将回绕到同一单元格的下一行。如果需要显示被回绕的文本,需要增加单元的列宽(ColWidth 属性)或行高(RowHeight 属性)。

使用 Col Row 属性可以分别确定 MSFlexGrid 中列与行的个数。


 

 

MSHFlexGrid 控件

Microsoft Hierarchical FlexGrid (MSHFlexGrid) 控件对表格数据进行显示和操作。在对包含字符串和图片的表格进行分类、合并以及格式化时,具有完全的灵活性。当绑定到 Data 控件上时,MSHFlexGrid 所显示的是只读数据。

语法

MSHFlexGrid

说明

可以将文本、图片,或者文本和图片,放在MSHFlexGrid 的任意单元中。Row Col 属性指定了MSHFlexGrid 中的当前单元。程序员可以在代码中指定当前单元,也可以在运行时,使用鼠标或者方向键来对其进行修改。Text 属性引用当前单元的内容。

 

如果单元的文本过长而不能在该单元中显示,而且 WordWrap 属性被设置为 True,那么文本就会换行到同一单元内的下一行。为了显示换行的文本,可能需要增加单元的列宽度(ColWidth 属性)或者行高度(RowHeight 属性)。

可以用 Cols Rows 属性来决定MSHFlexGrid 控件中的列数和行数。

显示层次结构记录集

MSHFlexGrid 控件的一个主要特性是它能显示层次结构记录集以层次结构方式显示的关系表。创建层次结构记录集的最容易的方法是使用数据环境设计器并把 MSHFlexGrid 控件的 DataSource 属性赋给数据环境。您也可以用 Shape 命令作为 ADO Data Control RecordSource 在代码中创建层次结构记录,如下面的示例:

' 创建 ConnectionString.

Dim strCn As String

strCn = "Provider=MSDataShape.1;Data Source=Nwind;" & _

"Connect Timeout=15;Data Provider=MSDASQL"

' 创建 Shape 命令.

Dim strSh As String

strSh = "SHAPE {SELECT * FROM `Customers`} AS Customers " & _

"APPEND ({SELECT * FROM `Orders`} AS Orders RELATE " & _

"CustomerID TO CustomerID) AS Orders"

' ConnectionString 赋给 ADO Data Control

' ConnectionString 属性, Shape 命令以及

' 控件的 RecordSource 属性.

With Adodc1

.ConnectionString = strCn

.RecordSource = strSh

End With

' HflexGrid 控件的 DataSource 属性设置到

' ADO Data 控件。

Set HFlexGrid1.DataSource = Adodc1

简单地说,Rows Cols属性就是规定该控制总的行列数。