Legen Sie die dataGridColumn-die ItemRenderer-dynamisch
Habe ich das DataGrid:
<mx:DataGrid id="myDataGrid">
<mx:columns>
<mx:DataGridColumn dataField="colA" headerText="Column A:" width="40"
headerRenderer="path.customComponents.VerticalHeader"
itemRenderer="path.customComponents.CustomDataGridItemRenderer" />
</mx:Columns>
</mx:DataGrid>
Nur ich weiß nicht im Voraus, wie viele Spalten es sein wird. Also ich habe versucht, den Bau der Spalten mit einer Funktion in ActionScript:
private var _columns:Array;
[Bindable]
public function set columns(value:Array):void
{
var c:Array = [];
for each(var object:Object in value)
{
var column:DataGridColumn = new DataGridColumn();
column.headerText=object.name;
column.width=40;
//Setting the Renderers like this doesn't work!
column.headerRenderer =
path.customComponents.VerticalHeader;
column.itemRenderer =
path.customComponents.CustomDataGridItemRenderer;
c.push(c);
}
myDataGrid.columns = c;
}
public function get columns():Array
{
return _columns;
}
Aber für einige Grund, die macht kann nicht festgelegt werden, wie diese. (Spalte.itemRenderer = com.ItemRenderer).
Was ist der richtige Weg, um diese rendert dynamisch?
Du musst angemeldet sein, um einen Kommentar abzugeben.
itemRenderer
undheaderRenderer
erwartet einemx.core.IFactory
als Wert. In mxml, der string-Wert übergeben wird, wird automatisch umgewandelt inmx.core.ClassFactory
. In ActionScript haben Sie es selbst zu tun.