我被困在以下问题上:
我有datagrid
10 个项目...我还添加了一个额外的行(第 11 行),其中显示了 prevouis 字段的总数...但我总是想将最后一行(总数)保留在最后一行数据网格(所以总是在位置 11)。
这意味着当数据网格按列排序时,最后一行的位置也会根据数据字段中的值发生变化。是否有任何简单直接的方法可以防止它与其他列一起排序,以便始终将具有总计的列放在最后?或者我最好使用什么方法?
谢谢你的帮助!
我被困在以下问题上:
我有datagrid
10 个项目...我还添加了一个额外的行(第 11 行),其中显示了 prevouis 字段的总数...但我总是想将最后一行(总数)保留在最后一行数据网格(所以总是在位置 11)。
这意味着当数据网格按列排序时,最后一行的位置也会根据数据字段中的值发生变化。是否有任何简单直接的方法可以防止它与其他列一起排序,以便始终将具有总计的列放在最后?或者我最好使用什么方法?
谢谢你的帮助!
请找到下面的代码希望这可以帮助你,我尝试了一些解决方法来实现你正在寻找的东西我不确定这段代码有多可行: -
<?xml version="1.0" encoding="utf-8"?>
<s:Application xmlns:fx="http://ns.adobe.com/mxml/2009"
xmlns:s="library://ns.adobe.com/flex/spark"
xmlns:mx="library://ns.adobe.com/flex/mx" minWidth="955" minHeight="600"
>
<fx:Declarations>
<!-- Place non-visual elements (e.g., services, value objects) here -->
</fx:Declarations>
<fx:Script>
<![CDATA[
import mx.collections.ArrayCollection;
import mx.events.FlexEvent;
[Bindable]
private var dpHierarchy:ArrayCollection= new ArrayCollection([
{name:"A", region: "Arizona", number:1},
{name:"B", region: "Arizona", number:2},
{name:"C", region: "California", number:3},
{name:"D", region: "California", number:4}
]);
private function creationComp():void
{
var totalValue:int = 0;
for(var i:int=0; i<dpHierarchy.length; i++)
{
totalValue = totalValue + dpHierarchy[i].number;
}
var obj:Object = new Object();
obj.name = "Total";
obj.region = "==";
obj.number = totalValue;
dpHierarchy.addItem(obj)
myADG.dataProvider = dpHierarchy;
}
private function sortHandler(obj1:Object, obj2:Object):int
{
var lastObj:Object = dpHierarchy.getItemAt(dpHierarchy.length-1);
if(lastObj.number == obj1.number || lastObj.number == obj2.number)
return 0;
if(obj1.number < obj2.number) {
return -1;
} else if(obj1 == obj2) {
return 0;
}
return 1;
}
]]>
</fx:Script>
<mx:AdvancedDataGrid id="myADG" x="50" y="50"
width="400" height="300"
variableRowHeight="true" creationComplete="creationComp()">
<mx:columns>
<mx:AdvancedDataGridColumn dataField="name" headerText="Name" sortCompareFunction="sortHandler"/>
<mx:AdvancedDataGridColumn dataField="region" headerText="Region" sortCompareFunction="sortHandler"/>
<mx:AdvancedDataGridColumn dataField="number" headerText="Number" sortCompareFunction="sortHandler"/>
</mx:columns>
</mx:AdvancedDataGrid>
</s:Application>
我会按这个顺序考虑几个选项。