天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

使用DataGrid中擴(kuò)展ItemRenderer和HeaderRenderer進(jìn)行操作

如果僅僅只是簡(jiǎ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ì)象。
復(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)了很長(zhǎng)時(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"/>

AspNet技術(shù)使用DataGrid中擴(kuò)展ItemRenderer和HeaderRenderer進(jìn)行操作,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 国产女人与黑人在线播放 | 99久久久久精品国产免费麻豆 | 91综合精品网站久久 | 18禁黄久久久AAA片 | 久久久久免费视频 | 伊人久久大香线蕉综合亚洲 | 国内精品一级毛片免费看 | 三级黄色小视频 | 翁止熄痒禁伦短文合集免费视频 | 午夜福利免费0948视频 | 亚洲精品国偷拍自产在线观看蜜臀 | 99精品成人无码A片观看金桔 | 精品国产午夜福利在线观看蜜月 | 国产精品2020观看久久 | 西西人体大胆牲交PP6777 | 国产精品一区二区人妻无码 | 麻婆豆腐传媒视频免费 | 成人影片大全 | 国产精品久久久久久无码专区 | 免费伦理片网站 | 内射少妇36P九色 | 亚洲熟妇无码乱子AV电影 | 樱桃熟了A级毛片 | 久久a在线视频观看 | 香蕉久久一区二区三区啪啪 | 国产精品嫩草影院在线观看免费 | 好男人免费观看在线高清WWW | 色悠久久久久综合网小说 | 欧美牲交A欧美牲交VDO | 中国拍三a级的明星女 | 无码国产成人午夜在线观看不卡 | 乱码中字在线观看一二区 | 97人人看碰人免费公开视频 | 久亚洲AV无码专区A片 | 欧美亚洲日韩自拍高清中文 | 色色色久久久免费视频 | 草神被爆漫画羞羞漫画 | 亚洲色欲色欲无码AV | 深喉吞精日本 | 色小说在线 | 99国产精品久久人妻无码 |