我已经将datagrid定义如下
<mx:DataGrid id="dg" width="100%" height="100%" >
在我尝试从数据库中获取详细信息并为DataGrid设置dataProvider的部分中,如下所示。
var arrayContent:ArrayCollection = new ArrayCollection();
for(var i:int=0;i<assetClassDetails.length;i++)
{
var assetClass_:AssetItemClassVO = new AssetItemClassVO();
var array:ArrayCollection = new ArrayCollection();
var embeddableLocale:EmbeddableAssetItemClassLocale = new EmbeddableAssetItemClassLocale();
var assetClassD_:AssetItemClassLocale = new AssetItemClassLocale();
assetClass_ = assetClassDetails.getItemAt(i) as AssetItemClassVO;
array = assetClass_.assetItemClassLocale;
if(assetClass_ != null && array != null && array.length >0)
{
assetClassD_ = array.getItemAt(0) as AssetItemClassLocale;
arrayContent.addItem(new Array(assetClass_.id,assetClassD_.name,assetClassD_.description,assetClassD_.locale,assetClass_.createdby,assetClass_.createdtime,assetClass_.lastmodifiedby,assetClass_.lastmodifiedtime));
}
}
dg.dataProvider = arrayContent;
但是这样做之后,我得到的列名是1,2,3,4,5 ...... 8。 但是我想将列名设置为ID,Name,Description,Locale,CreatedBy,CreatedTime,LastModifiedBy,LastModifiedTime。
我该怎么做?
请帮忙。
答案 0 :(得分:1)
我不确定arraycollection上的数据,也许你可以查看我的代码,我在Datagrid上创建动态表
private function addDataGridParamColumn(tmp:String):void
{
var dgColumn:DataGridColumn = new DataGridColumn(tmp);
var arr:Array = dg.columns;
dg.headerRenderer = new ClassFactory(Label);
switch(tmp)
{
case "Name":
dgColumn.dataField = 'Name';
dgColumn.width = 150;
dgColumn.itemRenderer = new ClassFactory(Label);
break;
}
arr.push(dgColumn);
dg.columns = arr;
}
你可以调用函数addDataGridParamColumn(这是名称标题)并添加用于循环的大小写
答案 1 :(得分:0)
不是100%确定你要做什么,但这里是DataGrid数据绑定的一个例子。希望它有所帮助。
<?xml version="1.0" encoding="utf-8"?>
<mx:Application initialize="init()"
xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute">
<mx:Script>
<![CDATA[
import mx.collections.ArrayCollection;
[Bindable]
private var employees:ArrayCollection;
private function init():void
{
employees = new ArrayCollection();
employees.addItem({name: "Oscar", phone: "907.123.4567", email: "oscar@isacat.net"});
employees.addItem({name: "Nimrod", phone: "907.876.5342", email: "nimrod@isacat.net"});
}
]]>
</mx:Script>
<mx:DataGrid id="dg" color="0x323232" width="100%" rowCount="3" dataProvider="{employees}">
<mx:columns>
<mx:DataGridColumn dataField="name" headerText="Name"/>
<mx:DataGridColumn dataField="phone" headerText="Phone"/>
<mx:DataGridColumn dataField="email" headerText="Email"/>
</mx:columns>
</mx:DataGrid>
</mx:Application>