0

我正在尝试对存储在 arraycollection 中的字符串列表进行排序。但排序结果不正确。请看我的代码。

spark.collections.Sort

if(value is ArrayCollection){
            var sort:Sort=new Sort();
            var sortField:SortField = new SortField("data")
            sortField.numeric=false;
            sort.fields=[sortField];

            ArrayCollection(value).sort=sort;
            ArrayCollection(value).refresh();
        }

输入:开始于、包含、结束于、等于忽略大小写、不等于、匹配、等于

输出:等于忽略大小写、包含、结束于、开始于、不等于、匹配、等于

有时只有一行与另一行交换(如上所述),有时根本没有排序。

4

1 回答 1

5

如果您的数组集合具有字符串列表。您无需为您的案例指定 SortField 的名称data

            var value:ArrayCollection = new ArrayCollection(['Start With','Contains','End With','Equals IgnoreCase','Not Equals','Equals']);
            var dataSortField:SortField = new SortField(); //Leave it empty.
            dataSortField.numeric = false;

            var dataSort:Sort = new Sort();
            dataSort.fields=[dataSortField];

            value.sort = dataSort;
            value.refresh();

o/p:

   "value"  mx.collections.ArrayCollection (@31ced61)   
[0] "Contains"  
[1] "End With"  
[2] "Equals"    
[3] "Equals IgnoreCase" 
[4] "Not Equals"    
[5] "Start With"

如果 arraycollection 具有具有数据属性的对象,则您的代码绝对正确。喜欢

            var value:ArrayCollection = new ArrayCollection();
            value.addItem({data:'Start With'});
            value.addItem({data:'Contains'});
            value.addItem({data:'End With'});
            value.addItem({data:'Equals IgnoreCase'});
            value.addItem({data:'Not Equals'});
            value.addItem({data:'Equals'});

这种情况你需要指定像

var sortField:SortField = new SortField("data");
于 2012-12-13T11:49:39.580 回答