• <fieldset id="8imwq"><menu id="8imwq"></menu></fieldset>
  • <bdo id="8imwq"><input id="8imwq"></input></bdo>
    最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
    問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
    當前位置: 首頁 - 科技 - 知識百科 - 正文

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

    來源:懂視網(wǎng) 責編:小采 時間:2020-11-27 22:44:46
    文檔

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

    使用DataGrid中擴展ItemRenderer和HeaderRenderer進行操作:如果僅僅只是簡單的顯示數(shù)據(jù),或者對顯示數(shù)據(jù)做一些格式化操作,基本的DataGrid,加labelFunction支持就可以滿足了,但大多我們需要針對不同的數(shù)據(jù)和對象,進行不同的渲染,比如checkbox啦,下拉選擇框,日期等等,再比如自己控制顯示復雜視圖,比如Gant
    推薦度:
    導讀使用DataGrid中擴展ItemRenderer和HeaderRenderer進行操作:如果僅僅只是簡單的顯示數(shù)據(jù),或者對顯示數(shù)據(jù)做一些格式化操作,基本的DataGrid,加labelFunction支持就可以滿足了,但大多我們需要針對不同的數(shù)據(jù)和對象,進行不同的渲染,比如checkbox啦,下拉選擇框,日期等等,再比如自己控制顯示復雜視圖,比如Gant

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

    (2)擴展DataGridColumn對象來增加屬性,傳遞參數(shù)。
    有些屬性我需要動態(tài)從外面?zhèn)鬟f進來,但有不屬于list data數(shù)據(jù)的部分。而Grid Header需要利用這些數(shù)據(jù)做一些渲染操作。這時候就需要擴展實現(xiàn)DataGridColumn對象,同時在HeaderRenderer對象中獲取此DataGridColumn對象來獲取參數(shù)。
    如下是擴展的一個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方法中,可以獲取相應的對象和參數(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進行顯示數(shù)據(jù)格式化
    比如我想對日期數(shù)據(jù)進行格式化操作,如下所示:
    代碼如下:

    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"/>

    聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

    文檔

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

    使用DataGrid中擴展ItemRenderer和HeaderRenderer進行操作:如果僅僅只是簡單的顯示數(shù)據(jù),或者對顯示數(shù)據(jù)做一些格式化操作,基本的DataGrid,加labelFunction支持就可以滿足了,但大多我們需要針對不同的數(shù)據(jù)和對象,進行不同的渲染,比如checkbox啦,下拉選擇框,日期等等,再比如自己控制顯示復雜視圖,比如Gant
    推薦度:
    • 熱門焦點

    最新推薦

    猜你喜歡

    熱門推薦

    專題
    Top
    主站蜘蛛池模板: 免费精品无码AV片在线观看 | 日本加勒比久久精品| 无码精品日韩中文字幕| Xx性欧美肥妇精品久久久久久| 久久精品夜夜夜夜夜久久| 久久99亚洲综合精品首页| 日韩精品www| 国产精品免费一区二区三区四区| 亚洲精品动漫免费二区| 精品国产成人在线| 91精品国产高清久久久久久91| 国产精品免费观看调教网| 亚洲欧美国产精品第1页| 精品日本一区二区三区在线观看| 91探花国产综合在线精品| 国产午夜精品一区理论片| 精品无码av一区二区三区| 亚洲精品无码久久久久| 免费精品久久久久久中文字幕 | 500av大全导航精品| 亚洲国产精品无码专区影院| 男女男精品视频网站在线观看| 国产999精品久久久久久| 久久国产精品成人免费| 久久精品九九亚洲精品天堂| 久久99精品久久久久久久久久| 亚洲精品乱码久久久久久| 亚洲国产精品成人| 日韩AV毛片精品久久久| 久久精品国产精品亚洲艾草网美妙| 国产精品电影在线| 91国内揄拍国内精品情侣对白| 中文字幕亚洲精品| 欧美日韩精品一区二区三区| 久久这里只有精品首页| 久久久精品午夜免费不卡| 国产精品日韩欧美制服| 91精品欧美综合在线观看| 国产精品久久久久影院嫩草| 精品国产免费一区二区三区香蕉| 国产a视频精品免费观看|