Flex中如何動(dòng)態(tài)生成DataGrid以及動(dòng)態(tài)生成表頭
更新時(shí)間:2013年10月29日 15:29:02 作者:
因某些需要,DataGrid及其表頭需要?jiǎng)討B(tài)生成,網(wǎng)上的解決方案打多籠統(tǒng),下面有個(gè)不錯(cuò)的解決方法,感興趣的朋友可以參考下
在Flex中動(dòng)態(tài)生成表格,并且表格的表頭也是動(dòng)態(tài)生成
1、源碼
<?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute"
creationComplete="initHandler()"
width="100%" height="100%">
<mx:Script>
<![CDATA[
import mx.events.FlexEvent;
import mx.events.ListEvent;
import mx.controls.ComboBox;
import mx.controls.DataGrid;
import mx.collections.ArrayCollection;
import mx.controls.dataGridClasses.DataGridColumn;
[Bindable]
//自定義數(shù)據(jù)源
private var grid:Array = [
{age:'25', sex: "男",name: "張三"},
{age:'22', sex: "女",name: "李四"},
{age:'23', sex: "男",name: "王五"},
{age:'21', sex: "女",name: "趙六"},
{age:'24', sex: "男",name: "錢七"},
{age:'20', sex: "女",name: "魏八"}
];
/*初始化函數(shù)*/
private function initHandler():void
{
var gridArray:ArrayCollection = new ArrayCollection(grid);
gridArray.filterFunction;
//自定義DataGrid控件
var dataGrid:DataGrid = new DataGrid();
//X軸坐標(biāo)
dataGrid.x = 20;
//Y軸坐標(biāo)
dataGrid.y = 20;
//數(shù)據(jù)項(xiàng)是否能編輯
dataGrid.editable = false;
//控件寬度
dataGrid.width = 1300;
//控件高度
//dataGrid.height = 600;
//設(shè)置表格行數(shù)
dataGrid.rowCount = gridArray.length + 1;
//設(shè)置控件內(nèi)容字體大小
dataGrid.setStyle("fontSize", 20);
//設(shè)置表頭顏色
dataGrid.setStyle("headerColors",[0xB0C4DE,0xB0C4DE]);
//設(shè)置字體位置
dataGrid.setStyle("textAlign","center");
//設(shè)置樣式名
dataGrid.styleName;
// 設(shè)置數(shù)據(jù)源
dataGrid.dataProvider = gridArray;
// 添加監(jiān)聽(tīng)事件類型與觸發(fā)函數(shù)
dataGrid.addEventListener(ListEvent.ITEM_CLICK, itemClickHandler);
// 添加dataGrid控件
addChild(dataGrid);
//聲明一個(gè)數(shù)組
var columns:Array = new Array();
var column:DataGridColumn;
for ( var i:* in grid[0] ) {
column = new DataGridColumn(i);
columns.push(column);
}
dataGrid.columns = columns;
}
/*事件*/
private function itemClickHandler(event:ListEvent):void
{
trace(event.target);
}
]]>
</mx:Script>
</mx:Application>
2、結(jié)果如下圖
1、源碼
復(fù)制代碼 代碼如下:
<?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute"
creationComplete="initHandler()"
width="100%" height="100%">
<mx:Script>
<![CDATA[
import mx.events.FlexEvent;
import mx.events.ListEvent;
import mx.controls.ComboBox;
import mx.controls.DataGrid;
import mx.collections.ArrayCollection;
import mx.controls.dataGridClasses.DataGridColumn;
[Bindable]
//自定義數(shù)據(jù)源
private var grid:Array = [
{age:'25', sex: "男",name: "張三"},
{age:'22', sex: "女",name: "李四"},
{age:'23', sex: "男",name: "王五"},
{age:'21', sex: "女",name: "趙六"},
{age:'24', sex: "男",name: "錢七"},
{age:'20', sex: "女",name: "魏八"}
];
/*初始化函數(shù)*/
private function initHandler():void
{
var gridArray:ArrayCollection = new ArrayCollection(grid);
gridArray.filterFunction;
//自定義DataGrid控件
var dataGrid:DataGrid = new DataGrid();
//X軸坐標(biāo)
dataGrid.x = 20;
//Y軸坐標(biāo)
dataGrid.y = 20;
//數(shù)據(jù)項(xiàng)是否能編輯
dataGrid.editable = false;
//控件寬度
dataGrid.width = 1300;
//控件高度
//dataGrid.height = 600;
//設(shè)置表格行數(shù)
dataGrid.rowCount = gridArray.length + 1;
//設(shè)置控件內(nèi)容字體大小
dataGrid.setStyle("fontSize", 20);
//設(shè)置表頭顏色
dataGrid.setStyle("headerColors",[0xB0C4DE,0xB0C4DE]);
//設(shè)置字體位置
dataGrid.setStyle("textAlign","center");
//設(shè)置樣式名
dataGrid.styleName;
// 設(shè)置數(shù)據(jù)源
dataGrid.dataProvider = gridArray;
// 添加監(jiān)聽(tīng)事件類型與觸發(fā)函數(shù)
dataGrid.addEventListener(ListEvent.ITEM_CLICK, itemClickHandler);
// 添加dataGrid控件
addChild(dataGrid);
//聲明一個(gè)數(shù)組
var columns:Array = new Array();
var column:DataGridColumn;
for ( var i:* in grid[0] ) {
column = new DataGridColumn(i);
columns.push(column);
}
dataGrid.columns = columns;
}
/*事件*/
private function itemClickHandler(event:ListEvent):void
{
trace(event.target);
}
]]>
</mx:Script>
</mx:Application>
2、結(jié)果如下圖

相關(guān)文章
在as中監(jiān)聽(tīng)自定義事件并處理事件的實(shí)例代碼
點(diǎn)擊一張圖片,響應(yīng)事件。必須在AS中,去監(jiān)聽(tīng)事件,并處理事件,下面是具體的實(shí)現(xiàn)思路及功能代碼,感興趣的朋友可以參考下哈2013-06-06Flex字體加粗問(wèn)題只能對(duì)英文的字體加粗
在flex中對(duì)label進(jìn)行字體加粗的時(shí)候,只能對(duì)英文的字體加粗,而中文的就不可以加粗,解決方法如下,希望對(duì)大家有所幫助2014-01-01flex通過(guò)java后臺(tái)獲取ip和pcname示例代碼
這篇文章主要介紹了flex通過(guò)java后臺(tái)獲取ip和pcname的具體實(shí)現(xiàn),需要的朋友可以參考下2014-05-05在Flex中給datagrid添加右鍵菜單項(xiàng)的具體實(shí)現(xiàn)
Flex中如何給datagrid添加右鍵菜單項(xiàng),其實(shí)很簡(jiǎn)單,下面有個(gè)不錯(cuò)的教程,感興趣的朋友可以參考下2013-12-12Flex 錯(cuò)誤(mx.messaging.messages::RemotingMessage)分析
有時(shí)我們?cè)谧鲰?xiàng)目的時(shí)候會(huì)遇到Flex 錯(cuò)誤提示mx.messaging.messages::RemotingMessage,那么產(chǎn)生這個(gè)錯(cuò)誤的原因是什么呢,今天我們來(lái)分析下2014-06-06flex chrome瀏覽器調(diào)試出現(xiàn)空白的解決方法
flex瀏覽器調(diào)試出現(xiàn)空白,原因是谷歌有個(gè)默認(rèn)的flash播放器,只要將默認(rèn)的播放器禁用,留下新安裝的插件,就OK了2014-02-02