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

使用DataGrid中擴展ItemRenderer和HeaderRenderer進行操作

如果僅僅只是簡單的顯示數據,或者對顯示數據做一些格式化操作,基本的DataGrid,加labelFunction支持就可以滿足了,但大多我們需要針對不同的數據和對象,進行不同的渲染,比如checkbox啦,下拉選擇框,日期等等,再比如自己控制顯示復雜視圖,比如Gantt圖之類。這就必須擴展ItemRenderer和HeaderRenderer。
(1)有關ItemRenderer的類實現IDataRenderer和IDropInListItemRenderer接口。
很多flex control類都默認實現了IDataRenderer接口,比如Button、Container、TextArea等等。很多flex control類也實現了IDropInListItemRenderer接口,但可惜Container沒有默認實現。而我做的東西,需要繪圖,所以直接利用Canvas擴展,就必須自己實現IDropInListItemRenderer接口,來獲取ListData對象。
復制代碼 代碼如下:
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;
}

可惜俺剛開始不知道之個,所以耗費了很長時間,花費在尋找如何獲取當前Column index問題上。
這樣,我才可以在setData方法中,獲取到DataGridColumn對象,如下(我使用的是AdvancedDataGrid對象):
復制代碼 代碼如下:
var dg:AdvancedDataGrid = this.owner as AdvancedDataGrid;
//listData就是實現IDropInListItemRenderer接口所可以獲取的
var gdgc:GanttAdvancedDataGridColumn =
dg.columns[listData.columnIndex] as GanttAdvancedDataGridColumn;
var dg:AdvancedDataGrid = this.owner as AdvancedDataGrid;
//listData就是實現IDropInListItemRenderer接口所可以獲取的
var gdgc:GanttAdvancedDataGridColumn =
dg.columns[listData.columnIndex] as GanttAdvancedDataGridColumn;

(2)擴展DataGridColumn對象來增加屬性,傳遞參數。
有些屬性我需要動態從外面傳遞進來,但有不屬于list data數據的部分。而Grid Header需要利用這些數據做一些渲染操作。這時候就需要擴展實現DataGridColumn對象,同時在HeaderRenderer對象中獲取此DataGridColumn對象來獲取參數。
如下是擴展的一個AdvanceDataGridColumn使用,在這個擴展中,增加了startDate和lastDate兩個屬性
復制代碼 代碼如下:
<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初始化的時候,在外部對此Column進行設置:
復制代碼 代碼如下:
ganttColumn.startDate = new Date(startTime);
ganttColumn.lastDate = new Date(lastTime);
ganttColumn.startDate = new Date(startTime);
ganttColumn.lastDate = new Date(lastTime);

在HeaderRenderer中,在setData方法中,可以獲取相應的對象和參數
復制代碼 代碼如下:
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進行顯示數據格式化
比如我想對日期數據進行格式化操作,如下所示:
復制代碼 代碼如下:
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中,就可以引用這個label function
復制代碼 代碼如下:
<mx:AdvancedDataGridColumn headerText="startTime" dataField="startTime" labelFunction="date_labelFunc" width="120"/>
<mx:AdvancedDataGridColumn headerText="startTime" dataField="startTime" labelFunction="date_labelFunc" width="120"/>

AspNet技術使用DataGrid中擴展ItemRenderer和HeaderRenderer進行操作,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 成人在线精品视频 | BT7086福利二区最新 | 亚洲国产精品第一影院在线观看 | 5g在线视讯年龄确认海外禁止进入 | 性色少妇AV蜜臀人妻无码 | 狠狠狠色丁香婷婷综合久久 | 国产精品人妻久久无码不卡 | 娇小老少配xxxxx | 欧美aa级片| 亚洲zooz人禽交xxxx | 久久久久久88色偷偷 | 小箩莉奶水四溅小说 | 女人会操出水图 | 亚洲精品高清在线观看 | 国产高清免费观看 | 永久免费看mv网站入口 | 免费看国产精品麻豆 | 插我一区二区在线观看 | 三叶草成人 | 色狠狠色综合吹潮 | 大胸美女被吊起来解开胸罩 | yellow免费观看直播 | 国产在线观看成人免费视频 | 亚欧日韩毛片在线看免费网站 | 久久中文字幕综合不卡一二区 | 日韩av片无码一区二区不卡电影 | 亚洲精品乱码久久久久久v 亚洲精品乱码电影在线观看 | 日韩一本道无码v | 全黄H全肉细节文短篇 | 交换邻居波多野结衣中文字幕 | 99热在线播放 | 狠狠色狠狠色综合日日32 | 湖南电台在线收听 | 越南女 黑人 痛苦 大叫 | 久久国产欧美日韩精品免费 | 午夜国产一区在线观看 | 日本综艺大尺度无删减版在线 | 久久操韩国自偷拍 | 综合人妻久久一区二区精品 | 人妻熟妇乱又伦精品视频中文字幕 | 午夜AV亚洲一码二中文字幕青青 |