按日期和时间对ArrayCollection进行排序-Flex



我有一个ArrayCollection,我想按日期和时间排序(以防有两个项目的日期相同)。我已经按日期(YYYY/MM/DD)进行了排序,但我无法计算出时间,时间是24小时的格式,所以代码与日期基本相同。

这是我用于日期排序的代码,它运行良好。

import mx.collections.SortField;
import mx.collections.Sort;
private function sort():void  
{
var dataSortField:SortField = new SortField();
dataSortField.name = "date";
var arrayDataSort:Sort = new Sort();
arrayDataSort.fields = [dataSortField];
reminderXMLArray.sort = arrayDataSort;
reminderXMLArray.refresh();
}

您可以使用此代码按日期和时间排序:

private function sort():void
{
    var dataSortField:SortField = new SortField();
    dataSortField.name = "date";
    dataSortField.compareFunction = function (a:Object, b:Object) : int {
        var na:Number = a.date.getTime();
        var nb:Number = b.date.getTime();
        if (na < nb)
            return -1;
        if (na > nb)
            return 1;
        return 0;
    };
    var arrayDataSort:Sort = new Sort();
    arrayDataSort.fields = [dataSortField];
    reminderXMLArray.sort = arrayDataSort;
    reminderXMLArray.refresh();
}

由于有两个单独的字段需要排序,您可以使用sort对象的字段Array添加两个排序字段:

var sort:Sort = new Sort();
var fields:Array = [ new SortField("date"), new SortField("time") ];
sort.fields = sort;

最新更新