简单地说,MSFlexGrid和MSHFlexGrid之间的区别,主要是后者支持ADO的层次显示。如果你不使用ADO,可以考虑MSFlexGrid,否则建议使用MSHFlexGrid。
这两个控件的详解:
MSFlexGrid控件
MicrosoftHierarchicalFlexGrid(MSHFlexGrid)控件对表格数据进行显示和操作。在对包含字符串和图片的表格进行分类、合并以及格式化时,具有完全的灵活性。当绑定到Data控件上时,MSHFlexGrid所显示的是只读数据。
语法
MSHFlexGrid
说明
可以将文本、图片,或者文本和图片,放在MSHFlexGrid的任意单元中。Row和Col属性指定了MSHFlexGrid中的当前单元。程序员可以在代码中指定当前单元,也可以在运行时,使用鼠标或者方向键来对其进行修改。Text属性引用当前单元的内容。
如果单元的文本过长而不能在该单元中显示,而且WordWrap属性被设置为True,那么文本就会换行到同一单元内的下一行。为了显示换行的文本,可能需要增加单元的列宽度(ColWidth属性)或者行高度(RowHeight属性)。
可以用Cols和Rows属性来决定MSHFlexGrid控件中的列数和行数。
显示层次结构记录集
MSHFlexGrid控件的一个主要特性是它能显示层次结构记录集—以层次结构方式显示的关系表。创建层次结构记录集的最容易的方法是使用数据环境设计器并把MSHFlexGrid控件的DataSource属性赋给数据环境。您也可以用Shape命令作为ADODataControl的RecordSource在代码中创建层次结构记录,如下面的示例:
'创建ConnectionString.
DimstrCnAsString strCn="Provider=MSDataShape.1;DataSource=Nwind;"&_ "ConnectTimeout=15;DataProvider=MSDASQL"
'创建Shape命令.
DimstrShAsString strSh="SHAPE{SELECT*FROM`Customers`}ASCustomers"&_ "APPEND({SELECT*FROM`Orders`}ASOrdersRELATE"&_ "CustomerIDTOCustomerID)ASOrders"
'把ConnectionString赋给ADODataControl的
'ConnectionString属性,Shape命令以及
'控件的RecordSource属性.
WithAdodc1 .ConnectionString=strCn .RecordSource=strSh EndWith
'把HflexGrid控件的DataSource属性设置到
'ADOData控件。
SetHFlexGrid1.DataSource=Adodc1
简单地说,RowsCols属性就是规定该控制总的行列数