Flash专栏: 基础教程 | 技巧运用 | MTV实例教程 | 游戏实例教程 | 实例教程 | AS教程(new)
photoshop专栏: 基础 | 进阶 | 技巧总汇 | 精彩实例 | 文字特效 | 滤镜魔术 | 实际应用
网页设计: Dreamweaver教程 | FireWorks教程 | CorelDraw设计 | Freehand/Illustrator教程 | 音乐转换教程
其他教程: 操作系统 | 程序设计 | 网站开发 | 图形图像 | 数据库 | 网络技术 | 安全相关 | 认证考试 | 硬件知识 | 服务器
Flash专栏>Flash技巧运用>Flex2 发现之旅:动态创建DataGrid列   返回上一页

  日期:2006-03-17 15 作者:hy feiy 来源:闪吧
天气预报 IP地址 手机号码 邮编 翻译 在线代理 在线评书 好dj


Flex2 发现之旅:动态创建DataGrid列


Flex2中,DataGrid如果我们没有指定columns熟悉的话,DataGrid会自动根据dataProvider的各行数据的属性名隐式自动地创建列,例如如下代码:

<?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.macromedia.com/2005/mxml" xmlns="*" 
  layout="vertical" creationComplete="loadDgView()">
 <mx:Script>
   <![CDATA[      
     [Bindable]
     public var works:Array= [
         ,
         ];
     private var worksColumns:Array= [
       ,
       ,
       ];
     [Bindable]
     public var departments:Array=[
       ,
       ];
     private var departmentsColumns:Array= [
       ,
       ];
     private function loadDgView(){
       if(type_cb.selectedIndex==0){          
         view_dg.dataProvider=works;
       }else{
         view_dg.dataProvider=departments;
       }
     }
   ]]>
 </mx:Script>
 <mx:HBox>   
   <mx:ComboBox id="type_cb" change="loadDgView()">
     <mx:dataProvider>
       <mx:Array>
         <mx:Object label="works"/>
         <mx:Object label="departments"/>
       </mx:Array>
     </mx:dataProvider>
   </mx:ComboBox>    
 </mx:HBox>
 <mx:DataGrid id="view_dg" />
</mx:Application>

查看示例

当我们选择works时,DataGrid自动根据dataProvider:works数组中的数据生成三列的DataGridColumn;而选择departments时,又相应的变更为两列,非常的方便。
DataGrid组件的这一功能是Flex1.5中所不具有的,是Flex2中的一大改进。
但是如果我们DataGrid的表头与列明不一致的时候,或者我们并不需要显示每行所有的数据,这时候DataGrid的隐式自动创建列的方法就不再适用了,这时候,我们就需要自己手动来创建列。
DataGrid使用columns属性来标识列信息,column属性是一个mx.controls.gridclasses.DataGridColumn数组,所以要动态创建表格列,只需要创建一个DataGridColumn数组,然后将其赋值给DataGrid的columns属性就可以了。前面示例的代码,我们改进如下:

<?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.macromedia.com/2005/mxml" xmlns="*" 
  layout="vertical" creationComplete="loadDgView()">
 <mx:Script>
   <![CDATA[
     import mx.controls.gridclasses.DataGridColumn;
     
     [Bindable]
     public var works:Array= [
         ,
         ];
     private var worksColumns:Array= [
       ,
       ,
       ];
     [Bindable]
     public var departments:Array=[
       ,
       ];
     private var departmentsColumns:Array= [
       ,
       ];
     private function loadDgView(){
       if(type_cb.selectedIndex==0){
         var columns:Array=new Array();
         for(var i:int;i<worksColumns.length;i++){
           var item:Object=worksColumns[i];
           var dgColumn:DataGridColumn=new DataGridColumn();
           dgColumn.columnName=item.columnName;
           dgColumn.headerText=item.headerText;
           dgColumn.width=item.width;
           columns.push(dgColumn);
         }
         view_dg.columns=columns;
         view_dg.dataProvider=works;
       }else{
         var columns:Array=new Array();
         for(var i:int;i<departmentsColumns.length;i++){
           var item:Object=departmentsColumns[i];
           var dgColumn:DataGridColumn=new DataGridColumn();
           dgColumn.columnName=item.columnName;
           dgColumn.headerText=item.headerText;
           dgColumn.width=item.width;
           columns.push(dgColumn);
         }
         view_dg.columns=columns;         
         view_dg.dataProvider=departments;
       }
     }
   ]]>
 </mx:Script>
 <mx:HBox>   
   <mx:ComboBox id="type_cb" change="loadDgView()">
     <mx:dataProvider>
       <mx:Array>
         <mx:Object label="works"/>
         <mx:Object label="departments"/>
       </mx:Array>
     </mx:dataProvider>
   </mx:ComboBox>    
 </mx:HBox>
 <mx:DataGrid id="view_dg" />
</mx:Application>

查看示例
红色部分为增加的代码,相对之前的代码,我们增加了两个数组:worksColumns和departmentsColumns,分别存放相应数据的DataGridColumn属性,然后在loadDgView函数中,根据相应的Column数组创建相应的DataGridColumn数组,最后将其赋值给view_db.columns。


 
高手云集 版权所有 1998-2006