始终将特定的Datagrid行保留在最后 - 同时使用排序

时间:2012-06-18 16:25:24

标签: actionscript-3 flex datagrid

我坚持以下事项:

我有一个datagrid有10个项目...我还添加了一个额外的行(第11行),我在那里显示了一些prevouis字段......但我总是希望保留最后一行(在Datagrid的最后一行(总是在11位)。

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

感谢您的帮助!

2 个答案:

答案 0 :(得分: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>

答案 1 :(得分:0)

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

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