按日期排序Javascript对象数组

rya*_*dlf 621 javascript datetime

假设我有一些对象的数组:

var array = [{id: 1, date: Mar 12 2012 10:00:00 AM}, {id: 2, date: Mar 8 2012 08:00:00 AM}];
Run Code Online (Sandbox Code Playgroud)

如何从最接近当前日期和时间的日期开始按日期元素对此数组进行排序?请记住,数组可能有很多对象,但为了简单起见,我使用了2.

我会使用sort函数和自定义比较器吗?

UPDATE

在我的具体情况下,我希望日期安排从最新到最旧.结果我不得不颠倒简单函数的逻辑:

array.sort(function(a, b) {
    a = new Date(a.dateModified);
    b = new Date(b.dateModified);
    return a>b ? -1 : a<b ? 1 : 0;
});
Run Code Online (Sandbox Code Playgroud)

这会对最近的日期进行排序.

Phr*_*ogz 1256

最简单的答案

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);
});
Run Code Online (Sandbox Code Playgroud)

更多通用答案

array.sort(function(o1,o2){
  if (sort_o1_before_o2)    return -1;
  else if(sort_o1_after_o2) return  1;
  else                      return  0;
});
Run Code Online (Sandbox Code Playgroud)

或者更简洁:

array.sort(function(o1,o2){
  return sort_o1_before_o2 ? -1 : sort_o1_after_o2 ? 1 : 0;
});
Run Code Online (Sandbox Code Playgroud)

通用,强大的答案

在所有数组上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;
  }
})();
Run Code Online (Sandbox Code Playgroud)

像这样使用它:

array.sortBy(function(o){ return o.date });
Run Code Online (Sandbox Code Playgroud)

如果您的日期不具有直接可比性,请与其进行比较,例如

array.sortBy(function(o){ return new Date( o.date ) });
Run Code Online (Sandbox Code Playgroud)

如果返回值数组,也可以使用此选项按多个条件排序:

// Sort by date, then score (reversed), then name
array.sortBy(function(o){ return [ o.date, -o.score, o.name ] };
Run Code Online (Sandbox Code Playgroud)

有关详细信息,请参阅http://phrogz.net/JS/Array.prototype.sortBy.js.

  • 如果您使用 TS 并且想要按日期属性对对象进行排序,您可以使用第一个选项,如下所示:`return +b.date - +a.date;` 进行降序排列,并反转 'a' &amp; 的顺序'b' 表示升序 (13认同)
  • 第一个 eg 语法在 angular7 上给出错误:算术运算的左侧必须是类型 'any'、'number'、'bigint' 或枚举类型 (8认同)
  • 不建议在sort方法内创建新的Date对象。正是由于这个原因而造成生产性能问题。不要在sort方法内分配内存(和GC)。 (7认同)
  • @Sireini 取决于日期属性的类型/格式,但如果它是标准“日期”对象,则 @Gal 的响应最快且无需分配。`ab` 注释在 Chrome 中实际上非常慢(https://jsperf.com/date-sort-mm/1)。如果日期只是 ISO 字符串,则最快的方式是比较它们 `a &gt; b ? 1:a&lt;b?-1:0`。 (4认同)
  • 在打字稿上,您可以执行 `array.sort((a: any, b: any) =&gt; (+new Date(b.date) - +new Date(a.date)))` (4认同)
  • 可能想使用 `Date.parse()` 而不是 `new Date()`? (3认同)
  • 为什么不简单回答“ return ba;”呢? (2认同)
  • @MikeMurko 你做了什么来修复它? (2认同)
  • @SURENDRANATHSONAWANE 将日期转换为 Unix 时间戳: return new Date(b.date).getTime() - new Date(a.date).getTime(); (2认同)

Gal*_*Gal 122

@Phrogz答案都很棒,但这里有一个很好的,更简洁的答案:

array.sort(function(a,b){return a.getTime() - b.getTime()});
Run Code Online (Sandbox Code Playgroud)

在这里找到:在Javascript中排序日期

  • TypeScript 在简单的“a - b”解决方案上抛出错误,但它与“getTime”方法配合得很好。 (16认同)
  • 直接进行数学运算'a - b`也行.所以,`array.sort((a,b)=> a - b)`(es6) (12认同)
  • `a.getTime() - b.getTime()` 比 `a - b` 快得多 (3认同)
  • 为了澄清这一点,减去两个“Date”对象就足够了。`-` 运算符调用对象的 `valueOf` 方法进行减法;并且“Date.valueOf”返回与“Date.getTime”相同的值。 (3认同)

Sar*_*ran 81

上面的答案都很好,这是我以 ES6 方式排序日期的实现,我使用Date.parse(是全局 Date 对象)这会将日期的字符串表示形式转换为毫秒数。而不是new Date每次都实例化对象。

var array = ["2021-08-10T07:24:30.087+0000" , "2021-09-30T07:24:30.087+0000", "2021-10-13T07:24:30.087+0000"];

// sorting with latest date
array.sort((a,b) => Date.parse(b) - Date.parse(a))
Run Code Online (Sandbox Code Playgroud)

  • 这对常规日期数组进行排序,而不是对具有日期属性的对象数组进行排序,这就是问题所在。 (4认同)

qw3*_*w3n 68

在纠正JSON后,这应该工作.

var array = [{id: 1, date:'Mar 12 2012 10:00:00 AM'},{id: 2, date:'Mar 8 2012 08:00:00 AM'}];


array.sort(function(a,b){
var c = new Date(a.date);
var d = new Date(b.date);
return c-d;
});
Run Code Online (Sandbox Code Playgroud)


gab*_*ish 37

您的数据需要一些更正:

var array = [{id: 1, date: "Mar 12 2012 10:00:00 AM"},{id: 2, date: "Mar 28 2012 08:00:00 AM"}];
Run Code Online (Sandbox Code Playgroud)

更正数据后,您可以使用以下代码:

function sortFunction(a,b){  
    var dateA = new Date(a.date).getTime();
    var dateB = new Date(b.date).getTime();
    return dateA > dateB ? 1 : -1;  
}; 

var array = [{id: 1, date: "Mar 12 2012 10:00:00 AM"},{id: 2, date: "Mar 28 2012 08:00:00 AM"}];
array.sort(sortFunction);?
Run Code Online (Sandbox Code Playgroud)

  • 对于任何使用 Typescript 的人来说,我都可以使用此函数按日期排序,而其他使用日期减法的函数则失败了。 (7认同)
  • [不要忘记在必要时返回`0`!](http://stackoverflow.com/q/20883421/1048572) (4认同)

jhe*_*rax 20

我推荐GitHub:Array sortBy - sortBy使用Schwartzian变换的方法的最佳实现

但是现在我们将尝试这种方法Gist:sortBy-old.js.
让我们创建一个方法来排序能够通过某些属性排列对象的数组.

创建排序功能

var sortBy = (function () {
  var toString = Object.prototype.toString,
      // default parser function
      parse = function (x) { return x; },
      // gets the item to be sorted
      getItem = function (x) {
        var isObject = x != null && typeof x === "object";
        var isProp = isObject && this.prop in x;
        return this.parser(isProp ? x[this.prop] : x);
      };

  /**
   * Sorts an array of elements.
   *
   * @param {Array} array: the collection to sort
   * @param {Object} cfg: the configuration options
   * @property {String}   cfg.prop: property name (if it is an Array of objects)
   * @property {Boolean}  cfg.desc: determines whether the sort is descending
   * @property {Function} cfg.parser: function to parse the items to expected type
   * @return {Array}
   */
  return function sortby (array, cfg) {
    if (!(array instanceof Array && array.length)) return [];
    if (toString.call(cfg) !== "[object Object]") cfg = {};
    if (typeof cfg.parser !== "function") cfg.parser = parse;
    cfg.desc = !!cfg.desc ? -1 : 1;
    return array.sort(function (a, b) {
      a = getItem.call(cfg, a);
      b = getItem.call(cfg, b);
      return cfg.desc * (a < b ? -1 : +(a > b));
    });
  };

}());
Run Code Online (Sandbox Code Playgroud)

设置未排序的数据

var data = [
  {date: "2011-11-14T17:25:45Z", quantity: 2, total: 200, tip: 0,   type: "cash"},
  {date: "2011-11-14T16:28:54Z", quantity: 1, total: 300, tip: 200, type: "visa"},
  {date: "2011-11-14T16:30:43Z", quantity: 2, total: 90,  tip: 0,   type: "tab"},
  {date: "2011-11-14T17:22:59Z", quantity: 2, total: 90,  tip: 0,   type: "tab"},
  {date: "2011-11-14T16:53:41Z", quantity: 2, total: 90,  tip: 0,   type: "tab"},
  {date: "2011-11-14T16:48:46Z", quantity: 2, total: 90,  tip: 0,   type: "tab"},
  {date: "2011-11-31T17:29:52Z", quantity: 1, total: 200, tip: 100, type: "visa"},
  {date: "2011-11-01T16:17:54Z", quantity: 2, total: 190, tip: 100, type: "tab"},
  {date: "2011-11-14T16:58:03Z", quantity: 2, total: 90,  tip: 0,   type: "tab"},
  {date: "2011-11-14T16:20:19Z", quantity: 2, total: 190, tip: 100, type: "tab"},
  {date: "2011-11-14T17:07:21Z", quantity: 2, total: 90,  tip: 0,   type: "tab"},
  {date: "2011-11-14T16:54:06Z", quantity: 1, total: 100, tip: 0,   type: "cash"}
];
Run Code Online (Sandbox Code Playgroud)

使用它

最后,我们按"date"属性排列数组string

//sort the object by a property (ascending)
//sorting takes into account uppercase and lowercase
sortBy(data, { prop: "date" });
Run Code Online (Sandbox Code Playgroud)

如果要忽略字母大小写,请设置"parser"回调:

//sort the object by a property (descending)
//sorting ignores uppercase and lowercase
sortBy(data, {
    prop: "date",
    desc: true,
    parser: function (item) {
        //ignore case sensitive
        return item.toUpperCase();
    }
});
Run Code Online (Sandbox Code Playgroud)

如果要将"日期"字段视为Date类型:

//sort the object by a property (ascending)
//sorting parses each item to Date type
sortBy(data, {
    prop: "date",
    parser: function (item) {
        return new Date(item);
    }
});
Run Code Online (Sandbox Code Playgroud)

在这里你可以玩上面的例子:
jsbin.com/lesebi


小智 20

arr 是一个对象数组,每个对象都有 date_prop 这是一个日期。您可以像这样按降序/降序对其进行排序

 arr = arr.sort(function (a, b) {
      var dateA = new Date(a.date_prop).getTime();
      var dateB = new Date(b.date_prop).getTime();
      return dateA < dateB ? 1 : -1; // ? -1 : 1 for ascending/increasing order
    });
Run Code Online (Sandbox Code Playgroud)

  • 如果日期相同则必须返回 0 (3认同)

sai*_*tam 14

带有日期的字符串在 JavaScript 中是可比较的(如果它们在语法上相同),例如:

'2020-12-01' < '2020-12-02' == true
Run Code Online (Sandbox Code Playgroud)

这意味着您可以在自定义排序函数中使用此表达式:

'2020-12-01' < '2020-12-02' == true
Run Code Online (Sandbox Code Playgroud)


Ben*_*hin 13

简单的一行解决方案让我对日期进行排序:

sort((a, b) => (a < b ? 1 : -1))
Run Code Online (Sandbox Code Playgroud)


Edi*_*uza 10

当你的日期采用这种格式时(dd/mm/yyyy),这应该可以.

  sortByDate(arr) {
    arr.sort(function(a,b){
      return Number(new Date(a.readableDate)) - Number(new Date(b.readableDate));
    });

    return arr;
  }
Run Code Online (Sandbox Code Playgroud)

sortByDate(myArr);


Rob*_*ert 9

您可以在下划线js中使用sortBy.

http://underscorejs.org/#sortBy

样品:

var log = [{date: '2016-01-16T05:23:38+00:00', other: 'sample'}, 
           {date: '2016-01-13T05:23:38+00:00',other: 'sample'}, 
           {date: '2016-01-15T11:23:38+00:00', other: 'sample'}];

console.log(_.sortBy(log, 'date'));
Run Code Online (Sandbox Code Playgroud)


Ara*_*chi 8

我个人使用以下方法对日期进行排序。

let array = ["July 11, 1960", "February 1, 1974", "July 11, 1615", "October 18, 1851", "November 12, 1995"];

array.sort(function(date1, date2) {
   date1 = new Date(date1);
   date2 = new Date(date2);
   if (date1 > date2) return 1;
   if (date1 < date2) return -1;
})
Run Code Online (Sandbox Code Playgroud)


Raj*_*ava 7

Adding absolute will give better results

var datesArray =[
      {"some":"data1","date": "2018-06-30T13:40:31.493Z"},
      {"some":"data2","date": "2018-07-04T13:40:31.493Z"},
      {"some":"data3","date": "2018-06-27T13:40:54.394Z"}
   ]

var sortedJsObjects = datesArray.sort(function(a,b){ 
    return Math.abs(new Date(a.date) - new Date(b.date)) 
});
Run Code Online (Sandbox Code Playgroud)


Jam*_*111 6

我将在此处添加此内容,因为某些用途可能无法确定如何反转此排序方法。

要按“出现”进行排序,我们可以简单地交换a和b,如下所示:

your_array.sort ( (a, b) => {
      return new Date(a.DateTime) - new Date(b.DateTime);
});
Run Code Online (Sandbox Code Playgroud)

注意,a它现在在左侧,而b在右侧,:D!


var*_*d11 6

使用 ES6 箭头函数,你可以进一步编写一行简洁的代码(不包括变量声明)。

例如。:

var isDescending = true; //set to false for ascending
console.log(["8/2/2020","8/1/2020","8/13/2020", "8/2/2020"].sort((a,b) => isDescending ? new Date(b).getTime() - new Date(a).getTime() : new Date(a).getTime() - new Date(b).getTime()));
Run Code Online (Sandbox Code Playgroud)

由于上述日期不存在时间,因此 Date 对象将考虑以下默认时间进行排序:

00:00:00

该代码适用于升序和降序排序。只需isDescending根据需要更改变量的值。


Dag*_*nqx 6

这是解决您的问题的最短方法。

  var array = [{id: 1, date: 'Mar 12 2012 10:00:00 AM'}, {id: 2, date: 'Mar 8 2012 08:00:00 AM'}];

  var sortedArray = array.sort((a,b) => Date.parse(new Date(a.date)) - Date.parse(new Date(b.date)));
Run Code Online (Sandbox Code Playgroud)

  • 如果只解析数据而不解析新日期,会更准确:`Date.parse(a.date)` (2认同)

Ama*_*rni 5

我能够使用以下几行实现排序:

array.sort(function(a, b)
{
   if (a.DueDate > b.DueDate) return 1;
   if (a.DueDate < b.DueDate) return -1;
})
Run Code Online (Sandbox Code Playgroud)