假设我有一些对象的数组:
var array = [{id: 1, date: Mar 12 2012 10:00:00 AM}, {id: 2, date: Mar 8 2012 08:00:00 AM}];
如何从最接近当前日期和时间的日期开始按date元素对该数组进行排序?请记住,数组可能有许多对象,但是为了简单起见,我使用了2。
我会使用排序功能和自定义比较器吗?
更新:
在我的特定情况下,我希望将日期从最近到最早安排。最后,我不得不逆转简单函数的逻辑:
array.sort(function(a, b) {
a = new Date(a.dateModified);
b = new Date(b.dateModified);
return a>b ? -1 : a<b ? 1 : 0;
});
这会将最新日期排序。
array.sort(function(a,b){
// Turn your strings into dates, and then subtract them
// to get a value that is either negative, positive, or zero.
return new Date(b.date) - new Date(a.date);
});
array.sort(function(o1,o2){
if (sort_o1_before_o2) return -1;
else if(sort_o1_after_o2) return 1;
else return 0;
});
或更简洁:
array.sort(function(o1,o2){
return sort_o1_before_o2 ? -1 : sort_o1_after_o2 ? 1 : 0;
});
在所有数组上sortBy
使用Schwartzian变换定义一个自定义不可枚举的函数:
(function(){
if (typeof Object.defineProperty === 'function'){
try{Object.defineProperty(Array.prototype,'sortBy',{value:sb}); }catch(e){}
}
if (!Array.prototype.sortBy) Array.prototype.sortBy = sb;
function sb(f){
for (var i=this.length;i;){
var o = this[--i];
this[i] = [].concat(f.call(o,o,i),o);
}
this.sort(function(a,b){
for (var i=0,len=a.length;i<len;++i){
if (a[i]!=b[i]) return a[i]<b[i]?-1:1;
}
return 0;
});
for (var i=this.length;i;){
this[--i]=this[i][this[i].length-1];
}
return this;
}
})();
像这样使用它:
array.sortBy(function(o){ return o.date });
如果您的日期不可直接比较,请在日期中加上可比较的日期,例如
array.sortBy(function(o){ return new Date( o.date ) });
如果返回值数组,还可以使用它来按多个条件排序:
// Sort by date, then score (reversed), then name
array.sortBy(function(o){ return [ o.date, -o.score, o.name ] };
有关更多详细信息,请参见http://phrogz.net/JS/Array.prototype.sortBy.js。
为什么
return b-a;
不简单回答?不建议在sort方法内创建新的Date对象。正是由于这个原因而造成生产性能问题。不要在sort方法内分配内存(和GC)。
第一个例如语法使angular7出现错误:算术运算的左侧必须为'any','number','bigint'或枚举类型