繁体   English   中英

Appcelerator钛/合金模型:如何修改此排序方法以对包含数字的字符串进行排序

[英]Appcelerator Titanium / Alloy Models: How do I modify this sorting method to sort a string that contains numbers

我已经在Appcelerator中创建了一个模型,该模型具有排序方法。 属性( date )之一是仅包含数字的字符串。 我需要按升序或降序对它进行排序,就好像它是整数一样。 但是,由于该字段是UTC日期时间戳,因此,较早的日期有时会显示较少的数字,并且以较大的数字开头,因此,按最新的日期排序时,这些日期将位于顶部,而按最旧的日期排序时,则将它们排列在底部。

这是我的模型文件:

exports.definition = {
    config: {
        columns: {
            "name": "text",
            "rating": "integer",
            "location": "text",
            "notes": "text",
            "date": "text",
            "latitude": "integer",
            "longitude": "integer",
            "api_id": "text"  
        },
        adapter: {
            type: "sql",
            collection_name: "test"
        }
    },
    extendModel: function(Model) {
        _.extend(Model.prototype, {
            // extended functions and properties go here
        });
        return Model;
    },
    extendCollection: function(Collection) {
        _.extend(Collection.prototype, {
            // extended functions and properties go here
            initialize: function () {
                 this.sortField = "date";
                 this.sortDirection = "DESC";
            },
            comparator: function (collection) {
                 var that = this;
                 return collection.get(that.sortField);
            },
            setSortField: function (field, direction) {
                this.sortField = field;
                this.sortDirection = direction;
            },
            sortBy: function (iterator, context) {
                var obj = this.models;
                var direction = this.sortDirection;

                return _.pluck(_.map(obj, function (value, index, list) {
                    return {
                        value: value,
                        index: index,
                        criteria: iterator.call(context, value, index, list)
                    };
                }).sort(function (left, right) {
                    // swap a and b for reverse sort
                    var a = direction === "ASC" ? left.criteria : right.criteria;
                    var b = direction === "ASC" ? right.criteria : left.criteria;

                    if (a !== b) {
                        if (a > b || a === void 0) return 1;
                        if (a < b || b === void 0) return -1;
                    }
                    return left.index < right.index ? -1 : 1;
                }), 'value');
            }
        });
        return Collection;
    }
};

这是我的index.js中对啤酒进行排序的代码

theBeers.setSortField("date", "ASC");
theBeers.sort();

如何修改上面的代码来解决此问题?

记住,我仍然需要其他属性,这些属性是按常规排序的字符串,例如namelocation等。

最好的方法是在比较之前将日期转换为整数,简单地说:

您需要为sort字段声明一个局部变量,与direction相同:

var field = this.sortField;

在if语句之前,添加以下内容:

if (field == "date") {
    a = parseInt(a);
    b = parseInt(b);
}

可能需要像代码中一样添加对void的检查。

如此完整的答案:

    sortBy: function (iterator, context) {
            var obj = this.models;
            var direction = this.sortDirection;
            var field = this.sortField;

            return _.pluck(_.map(obj, function (value, index, list) {
                return {
                    value: value,
                    index: index,
                    criteria: iterator.call(context, value, index, list)
                };
            }).sort(function (left, right) {
                // swap a and b for reverse sort
                var a = direction === "ASC" ? left.criteria : right.criteria;
                var b = direction === "ASC" ? right.criteria : left.criteria;

                if (field == "date") {
                    a = parseInt(a);
                    b = parseInt(b);
                }

                if (a !== b) {
                    if (a > b || a === void 0) return 1;
                    if (a < b || b === void 0) return -1;
                }
                return left.index < right.index ? -1 : 1;
            }), 'value');
        }

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM