使用DataGrid中擴(kuò)展ItemRenderer和HeaderRenderer進(jìn)行操作
更新時(shí)間:2009年02月06日 02:50:33 作者:
這兩天在用Flex DataGrid做點(diǎn)東西,走了不少彎路,現(xiàn)將心得分享一下。
如果僅僅只是簡單的顯示數(shù)據(jù),或者對(duì)顯示數(shù)據(jù)做一些格式化操作,基本的DataGrid,加labelFunction支持就可以滿足了,但大多我們需要針對(duì)不同的數(shù)據(jù)和對(duì)象,進(jìn)行不同的渲染,比如checkbox啦,下拉選擇框,日期等等,再比如自己控制顯示復(fù)雜視圖,比如Gantt圖之類。這就必須擴(kuò)展ItemRenderer和HeaderRenderer。
(1)有關(guān)ItemRenderer的類實(shí)現(xiàn)IDataRenderer和IDropInListItemRenderer接口。
很多flex control類都默認(rèn)實(shí)現(xiàn)了IDataRenderer接口,比如Button、Container、TextArea等等。很多flex control類也實(shí)現(xiàn)了IDropInListItemRenderer接口,但可惜Container沒有默認(rèn)實(shí)現(xiàn)。而我做的東西,需要繪圖,所以直接利用Canvas擴(kuò)展,就必須自己實(shí)現(xiàn)IDropInListItemRenderer接口,來獲取ListData對(duì)象。
private var _listData:BaseListData;
// Make the listData property bindable.
[Bindable("dataChange")]
public function get listData():BaseListData
{
return _listData;
}
public function set listData(value:BaseListData):void
{
_listData = value;
}
private var _listData:BaseListData;
// Make the listData property bindable.
[Bindable("dataChange")]
public function get listData():BaseListData
{
return _listData;
}
public function set listData(value:BaseListData):void
{
_listData = value;
}
可惜俺剛開始不知道之個(gè),所以耗費(fèi)了很長時(shí)間,花費(fèi)在尋找如何獲取當(dāng)前Column index問題上。
這樣,我才可以在setData方法中,獲取到DataGridColumn對(duì)象,如下(我使用的是AdvancedDataGrid對(duì)象):
var dg:AdvancedDataGrid = this.owner as AdvancedDataGrid;
//listData就是實(shí)現(xiàn)IDropInListItemRenderer接口所可以獲取的
var gdgc:GanttAdvancedDataGridColumn =
dg.columns[listData.columnIndex] as GanttAdvancedDataGridColumn;
var dg:AdvancedDataGrid = this.owner as AdvancedDataGrid;
//listData就是實(shí)現(xiàn)IDropInListItemRenderer接口所可以獲取的
var gdgc:GanttAdvancedDataGridColumn =
dg.columns[listData.columnIndex] as GanttAdvancedDataGridColumn;
(2)擴(kuò)展DataGridColumn對(duì)象來增加屬性,傳遞參數(shù)。
有些屬性我需要?jiǎng)討B(tài)從外面?zhèn)鬟f進(jìn)來,但有不屬于list data數(shù)據(jù)的部分。而Grid Header需要利用這些數(shù)據(jù)做一些渲染操作。這時(shí)候就需要擴(kuò)展實(shí)現(xiàn)DataGridColumn對(duì)象,同時(shí)在HeaderRenderer對(duì)象中獲取此DataGridColumn對(duì)象來獲取參數(shù)。
如下是擴(kuò)展的一個(gè)AdvanceDataGridColumn使用,在這個(gè)擴(kuò)展中,增加了startDate和lastDate兩個(gè)屬性
<gantt:GanttAdvancedDataGridColumn id="ganttColumn" headerText="Gantt" itemRenderer="{ganttItemEditor}" headerRenderer="{ganttHeaderEditor}" minWidth="400"/>
<gantt:GanttAdvancedDataGridColumn id="ganttColumn" headerText="Gantt" itemRenderer="{ganttItemEditor}" headerRenderer="{ganttHeaderEditor}" minWidth="400"/>
這樣,就可以在application初始化的時(shí)候,在外部對(duì)此Column進(jìn)行設(shè)置:
ganttColumn.startDate = new Date(startTime);
ganttColumn.lastDate = new Date(lastTime);
ganttColumn.startDate = new Date(startTime);
ganttColumn.lastDate = new Date(lastTime);
在HeaderRenderer中,在setData方法中,可以獲取相應(yīng)的對(duì)象和參數(shù)
override public function set data(value:Object):void{
super.data = value;
var advancedDataGridColumn:GanttAdvancedDataGridColumn
= value as GanttAdvancedDataGridColumn;
if(advancedDataGridColumn!=null){
if(advancedDataGridColumn.startDate!=null){
startDate = advancedDataGridColumn.startDate;
lastDate = advancedDataGridColumn.lastDate;
render();
}
}
}
override public function set data(value:Object):void{
super.data = value;
var advancedDataGridColumn:GanttAdvancedDataGridColumn
= value as GanttAdvancedDataGridColumn;
if(advancedDataGridColumn!=null){
if(advancedDataGridColumn.startDate!=null){
startDate = advancedDataGridColumn.startDate;
lastDate = advancedDataGridColumn.lastDate;
render();
}
}
}
(3)利用labelFunction進(jìn)行顯示數(shù)據(jù)格式化
比如我想對(duì)日期數(shù)據(jù)進(jìn)行格式化操作,如下所示:
private function date_labelFunc(item:Object, column:AdvancedDataGridColumn):String {
var dateFormatter:DateFormatter = new DateFormatter();
dateFormatter.formatString = "YYYY-MM-DD HH:NN";
var td:Date = new Date( new Number(item[column.dataField]) );
return dateFormatter.format( td );
}
private function date_labelFunc(item:Object, column:AdvancedDataGridColumn):String {
var dateFormatter:DateFormatter = new DateFormatter();
dateFormatter.formatString = "YYYY-MM-DD HH:NN";
var td:Date = new Date( new Number(item[column.dataField]) );
return dateFormatter.format( td );
}
在mx的datagridcolumn中,就可以引用這個(gè)label function
<mx:AdvancedDataGridColumn headerText="startTime" dataField="startTime" labelFunction="date_labelFunc" width="120"/>
<mx:AdvancedDataGridColumn headerText="startTime" dataField="startTime" labelFunction="date_labelFunc" width="120"/>
(1)有關(guān)ItemRenderer的類實(shí)現(xiàn)IDataRenderer和IDropInListItemRenderer接口。
很多flex control類都默認(rèn)實(shí)現(xiàn)了IDataRenderer接口,比如Button、Container、TextArea等等。很多flex control類也實(shí)現(xiàn)了IDropInListItemRenderer接口,但可惜Container沒有默認(rèn)實(shí)現(xiàn)。而我做的東西,需要繪圖,所以直接利用Canvas擴(kuò)展,就必須自己實(shí)現(xiàn)IDropInListItemRenderer接口,來獲取ListData對(duì)象。
復(fù)制代碼 代碼如下:
private var _listData:BaseListData;
// Make the listData property bindable.
[Bindable("dataChange")]
public function get listData():BaseListData
{
return _listData;
}
public function set listData(value:BaseListData):void
{
_listData = value;
}
private var _listData:BaseListData;
// Make the listData property bindable.
[Bindable("dataChange")]
public function get listData():BaseListData
{
return _listData;
}
public function set listData(value:BaseListData):void
{
_listData = value;
}
可惜俺剛開始不知道之個(gè),所以耗費(fèi)了很長時(shí)間,花費(fèi)在尋找如何獲取當(dāng)前Column index問題上。
這樣,我才可以在setData方法中,獲取到DataGridColumn對(duì)象,如下(我使用的是AdvancedDataGrid對(duì)象):
復(fù)制代碼 代碼如下:
var dg:AdvancedDataGrid = this.owner as AdvancedDataGrid;
//listData就是實(shí)現(xiàn)IDropInListItemRenderer接口所可以獲取的
var gdgc:GanttAdvancedDataGridColumn =
dg.columns[listData.columnIndex] as GanttAdvancedDataGridColumn;
var dg:AdvancedDataGrid = this.owner as AdvancedDataGrid;
//listData就是實(shí)現(xiàn)IDropInListItemRenderer接口所可以獲取的
var gdgc:GanttAdvancedDataGridColumn =
dg.columns[listData.columnIndex] as GanttAdvancedDataGridColumn;
(2)擴(kuò)展DataGridColumn對(duì)象來增加屬性,傳遞參數(shù)。
有些屬性我需要?jiǎng)討B(tài)從外面?zhèn)鬟f進(jìn)來,但有不屬于list data數(shù)據(jù)的部分。而Grid Header需要利用這些數(shù)據(jù)做一些渲染操作。這時(shí)候就需要擴(kuò)展實(shí)現(xiàn)DataGridColumn對(duì)象,同時(shí)在HeaderRenderer對(duì)象中獲取此DataGridColumn對(duì)象來獲取參數(shù)。
如下是擴(kuò)展的一個(gè)AdvanceDataGridColumn使用,在這個(gè)擴(kuò)展中,增加了startDate和lastDate兩個(gè)屬性
復(fù)制代碼 代碼如下:
<gantt:GanttAdvancedDataGridColumn id="ganttColumn" headerText="Gantt" itemRenderer="{ganttItemEditor}" headerRenderer="{ganttHeaderEditor}" minWidth="400"/>
<gantt:GanttAdvancedDataGridColumn id="ganttColumn" headerText="Gantt" itemRenderer="{ganttItemEditor}" headerRenderer="{ganttHeaderEditor}" minWidth="400"/>
這樣,就可以在application初始化的時(shí)候,在外部對(duì)此Column進(jìn)行設(shè)置:
復(fù)制代碼 代碼如下:
ganttColumn.startDate = new Date(startTime);
ganttColumn.lastDate = new Date(lastTime);
ganttColumn.startDate = new Date(startTime);
ganttColumn.lastDate = new Date(lastTime);
在HeaderRenderer中,在setData方法中,可以獲取相應(yīng)的對(duì)象和參數(shù)
復(fù)制代碼 代碼如下:
override public function set data(value:Object):void{
super.data = value;
var advancedDataGridColumn:GanttAdvancedDataGridColumn
= value as GanttAdvancedDataGridColumn;
if(advancedDataGridColumn!=null){
if(advancedDataGridColumn.startDate!=null){
startDate = advancedDataGridColumn.startDate;
lastDate = advancedDataGridColumn.lastDate;
render();
}
}
}
override public function set data(value:Object):void{
super.data = value;
var advancedDataGridColumn:GanttAdvancedDataGridColumn
= value as GanttAdvancedDataGridColumn;
if(advancedDataGridColumn!=null){
if(advancedDataGridColumn.startDate!=null){
startDate = advancedDataGridColumn.startDate;
lastDate = advancedDataGridColumn.lastDate;
render();
}
}
}
(3)利用labelFunction進(jìn)行顯示數(shù)據(jù)格式化
比如我想對(duì)日期數(shù)據(jù)進(jìn)行格式化操作,如下所示:
復(fù)制代碼 代碼如下:
private function date_labelFunc(item:Object, column:AdvancedDataGridColumn):String {
var dateFormatter:DateFormatter = new DateFormatter();
dateFormatter.formatString = "YYYY-MM-DD HH:NN";
var td:Date = new Date( new Number(item[column.dataField]) );
return dateFormatter.format( td );
}
private function date_labelFunc(item:Object, column:AdvancedDataGridColumn):String {
var dateFormatter:DateFormatter = new DateFormatter();
dateFormatter.formatString = "YYYY-MM-DD HH:NN";
var td:Date = new Date( new Number(item[column.dataField]) );
return dateFormatter.format( td );
}
在mx的datagridcolumn中,就可以引用這個(gè)label function
復(fù)制代碼 代碼如下:
<mx:AdvancedDataGridColumn headerText="startTime" dataField="startTime" labelFunction="date_labelFunc" width="120"/>
<mx:AdvancedDataGridColumn headerText="startTime" dataField="startTime" labelFunction="date_labelFunc" width="120"/>
相關(guān)文章
ASP.NET生成樹形顯示的GridView實(shí)現(xiàn)思路
生成樹形結(jié)構(gòu)的表格數(shù)據(jù)(EasyUI也有TreeGrid,此處只是提供一個(gè)思路),可以擴(kuò)展單擊展開/收縮節(jié)點(diǎn),喜歡的朋友可以了解下啊,或許本文對(duì)你學(xué)習(xí)GridView有所幫助2013-02-02
ASP.NET MVC傳送參數(shù)至服務(wù)端詳解及實(shí)例
這篇文章主要介紹了ASP.NET MVC傳送參數(shù)至服務(wù)端詳解及實(shí)例的相關(guān)資料,需要的朋友可以參考下2016-11-11
.Net使用SuperSocket框架實(shí)現(xiàn)WebSocket后端
這篇文章介紹了.Net使用SuperSocket框架實(shí)現(xiàn)WebSocket后端,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-01-01
ASP.Net MVC+Data Table實(shí)現(xiàn)分頁+排序功能的方法
這篇文章主要介紹了ASP.Net MVC+Data Table實(shí)現(xiàn)分頁+排序功能的方法,結(jié)合實(shí)例形式分析了asp.net基于mvc架構(gòu)實(shí)現(xiàn)的數(shù)據(jù)查詢、排序、分頁顯示等相關(guān)操作技巧,需要的朋友可以參考下2017-06-06
asp.net后臺(tái)cs中的JSON格式變量在前臺(tái)Js中調(diào)用方法(前后臺(tái)示例代碼)
本文主要介紹下asp.net后臺(tái)cs中的JSON格式變量在前臺(tái)Js中調(diào)用方法,下面是前后臺(tái)的實(shí)現(xiàn)代碼,感興趣的朋友可以參考下哈,下對(duì)大家有所幫助2013-06-06
Visual Studio 2019 使用 Live Share的教程圖解
Visual Studio 2019 在今天發(fā)布(北京時(shí)間)了,這次帶來了一個(gè)比較有趣的 Live Share 功能,使用它可以進(jìn)行更好的協(xié)作開發(fā)。這篇文章主要介紹了Visual Studio 2019 使用 Live Share的教程,需要的朋友可以參考下2019-04-04
關(guān)于DDD:管理"工作單元實(shí)例"的兩種模式的使用方法
本篇文章介紹了,關(guān)于DDD:管理"工作單元實(shí)例"的兩種模式的使用方法。需要的朋友參考下2013-04-04

