0

我被困在以下问题上:

我有datagrid10 个项目...我还添加了一个额外的行(第 11 行),其中显示了 prevouis 字段的总数...但我总是想将最后一行(总数)保留在最后一行数据网格(所以总是在位置 11)。

这意味着当数据网格按列排序时,最后一行的位置也会根据数据字段中的值发生变化。是否有任何简单直接的方法可以防止它与其他列一起排序,以便始终将具有总计的列放在最后?或者我最好使用什么方法?

谢谢你的帮助!

4

2 回答 2

1

请找到下面的代码希望这可以帮助你,我尝试了一些解决方法来实现你正在寻找的东西我不确定这段代码有多可行: -

<?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>
于 2012-06-19T06:13:46.857 回答
0

我会按这个顺序考虑几个选项。

  1. 将您的摘要数据放在其他地方。这真的不是数据网格中的一行的用途。
  2. 如果您真的不希望用户对数据进行排序,请不要让用户通过单击列名 (sortableColumns='false') 进行排序。
  3. 为每列创建自定义排序,确保您始终将汇总数据放在最后。这是一个不错的教程:http ://www.switchonthecode.com/tutorials/flex-datagrid-custom-sorting 。我想强调这将是一个高维护的想法,因为您必须为每一列构建自定义排序。
于 2012-06-18T18:22:53.210 回答