Apache flex 在Flex数据网格中将一组行转换为列
我有一个像下面这样的数组Apache flex 在Flex数据网格中将一组行转换为列,apache-flex,datagrid,Apache Flex,Datagrid,我有一个像下面这样的数组 public var sal:Array=[ {empNo:1001, sal:1000, exp:400}, {empNo:1002, sal:3000, exp:240}, {empNo:1003, sal:1000, exp:452}, {empNo:1004, sal:5000, exp:348}, ...... {empNo:1550, sal:2000, exp:330},
public var sal:Array=[
{empNo:1001, sal:1000, exp:400},
{empNo:1002, sal:3000, exp:240},
{empNo:1003, sal:1000, exp:452},
{empNo:1004, sal:5000, exp:348},
......
{empNo:1550, sal:2000, exp:330},
];
我需要使用3行flex数据网格显示数据,其中第一行显示empNo,第二行显示相应的工资(字段sal),第三行显示支出(字段exp)
你能告诉我怎么做吗?实际上,我的意思是数据将以下面给出的格式进入数据网格 第1行:->Emp编号1001 1002 1003 第2行:->Sal 1000 第3行:->exp 400 240 452这是您的解决方案
<?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute" initialize="formatData()">
<mx:Script>
<![CDATA[
import mx.controls.advancedDataGridClasses.AdvancedDataGridColumn;
import mx.collections.ArrayCollection;
[Bindable]
var dp:ArrayCollection=new ArrayCollection();
private function formatData():void
{
var salArray:Array=[{empNo: 1001, sal: 1000, exp: 400}, {empNo: 1002, sal: 3000, exp: 240}, {empNo: 1003, sal: 1000, exp: 452}, {empNo: 1004, sal: 5000, exp: 348}];
var i:int=0;
var empNo:Object=new Object();
var sal:Object=new Object();
var exp:Object=new Object();
var columns:Array = new Array();
for (i=0; i < salArray.length; i++)
{
empNo["col"+i]=salArray[i].empNo;
sal["col"+i]=salArray[i].sal;
exp["col"+i]=salArray[i].exp;
var advancedDataGridColumn:AdvancedDataGridColumn=new AdvancedDataGridColumn();
advancedDataGridColumn.dataField="col"+i;
columns.push(advancedDataGridColumn);
}
dp.addItem(empNo);
dp.addItem(sal);
dp.addItem(exp);
adg1.columns=columns;
adg1.invalidateDisplayList();
}
]]>
</mx:Script>
<mx:AdvancedDataGrid x="40.5" y="163" id="adg1" designViewDataType="flat" dataProvider="{dp}">
</mx:AdvancedDataGrid>
</mx:Application>
我想这就是你所问的:)嗨,你能详细解释一下“3行flex数据网格”是什么意思吗