Вопрос по javascript – Сортировать массив объектов Javascript по дате

500

Скажем, у меня есть массив из нескольких объектов:

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

Как я могу отсортировать этот массив по элементу даты в порядке от даты, ближайшей к текущей дате и времени вниз? Имейте в виду, что в массиве может быть много объектов, но для простоты я использовал 2.

Буду ли я использовать функцию сортировки и пользовательский компаратор?

UPDATE

В моем конкретном случае я хотел, чтобы даты были расположены от самых последних до самых старых. В итоге мне пришлось изменить логику простой функции следующим образом:

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

Это сортирует даты из самых последних.

Ваш объект недействителен. пожалуйста, предоставьте, как это на самом деле выглядит. Daniel A. White
вероятно, в виде строки - у AFAIK нет формата кодирования JSON для объектов даты. Alnitak
как на самом деле хранятся даты? как галочки или строки? Daniel A. White
Они извлекаются из базы данных как метка времени и передаются в Javascript через JSON. Так что строка? Я предполагаю, что строка должна быть преобразована в объект даты, прежде чем ее можно будет правильно отсортировать. ryandlf
В качестве альтернативы, чтобы получить обратную сортировку, вы можете просто сделатьreturn (new Date(b.date) - new Date(a.date)) * -1 Mike Wade

Ваш Ответ

15   ответов
26

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

После исправления данных вы можете использовать этот фрагмент кода:

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);​
Мне нравится этот ответ, потому что он учитывает время, а не просто дату (точнее). Кроме того, этот ответ является исчерпывающим, показывая сборку массива и использование функции. Другие предыдущие ответы отсутствуют пример, как использовать.
0
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)) 
});
-2
["12 Jan 2018" , "1 Dec 2018", "04 May 2018"].sort(function(a,b) {
    return new Date(a).getTime() - new Date(b).getTime()
})
Пожалуйста, кратко объясните свой ответ и проверьте формат вашего кода.
Не удастся на старые даты.
17

GitHub: Array sortBy - лучшая реализацияsortBy метод, который используетПреобразование Шварца

Но сейчас мы собираемся попробовать этот подходСуть: sortBy-old.js.
Давайте создадим метод сортировки массивов, способный упорядочивать объекты по какому-либо свойству.

Creating the sorting function
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));
    });
  };

}());
Setting unsorted data
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"}
];
Using it

Наконец, мы организуем массив,"date" собственность какstring

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

Если вы хотите игнорировать регистр букв, установите"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();
    }
});

Если вы хотите обработать & quot; дату & quot; поле как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);
    }
});

Здесь вы можете поиграть с приведенным выше примером:
jsbin.com/lesebi

В IE11 возникла проблема со строкой: if (toString.call (cfg)! == & quot; [объект Object] & quot;) cfg = {}; Если вы замените его на if (Object.prototype.toString.call (cfg)! == & quot; [объект Object] & quot;) cfg = {}; с IE11 у вас все будет хорошо.
0

YYYY[-MM[-DD]] если вы хотите заказать более конкретные даты, а не менее конкретные, я разработал эту удобную функцию:

const sortByDateSpecificity = (a, b) => {
  const aLength = a.date.length
  const bLength = b.date.length
  const aDate = a.date + (aLength < 10 ? '-12-31'.slice(-10 + aLength) : '')
  const bDate = b.date + (bLength < 10 ? '-12-31'.slice(-10 + bLength) : '')
  return new Date(aDate) - new Date(bDate)
}
2

array.sort(function(a, b) {
if (a.AffiliateDueDate > b.AffiliateDueDate) return 1;
if (a.AffiliateDueDate < b.AffiliateDueDate) return -1;
                                   })
84

array.sort(function(a,b){return a.getTime() - b.getTime()});

нашел здесь:Дата сортировки в Javascript

Работает отлично. Я использовал это, чтобы отсортировать массив моего объекта по дате. - & GT; array.sort (function (a, b) {return a.data.date.getTime () - b.data.date.getTime ()});
Делать математику напрямуюa - b также будет работать. Так,array.sort((a, b) => a - b) (ES6)
полу-связанный: машинопись также генерирует исключение типа, если вы пытаетесь вычесть их напрямую
Хотя, если верить критериям, мы бы НЕ хотели делатьa - b непосредственно
1061
Simplest Answer
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);
});
More Generic Answer
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;
});
Generic, Powerful Answer

Определить пользовательский не перечисляемыйsortBy функция с использованиемПреобразование Шварца на всех массивах:

(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 ] };

See http://phrogz.net/JS/Array.prototype.sortBy.js Больше подробностей.

Нет ли способа использовать уже встроенную функцию сортировки, в отличие от прототипа? ryandlf
Я принял это просто потому, что он более полный и предлагает несколько решений. @ qw3n также опубликовал вполне приемлемый ответ. ryandlf
Почему просто нетreturn b-a; в простом ответе?
@Phrogz, когда вы хотитеString по убыванию,sortBy не работает, потому что- оператор минус пытается преобразоватьstring вnumber, производяNaN значение. Я написал новыйsortBy метод вдохновлен вашимSchwartzian transform реализация, чтобы преодолеть эту проблему.https://gist.github.com/jherax, Любое предложение от вас приветствуется.
@ryandlf Я добавил короткий раздел, показывающий, как использовать это непосредственно для этого случая.
0

Преобразование Шварца изображено выше и сделано как функция. Требуетсяarrayсортировкаfunction и логическое значение в качестве входных данных:

function schwartzianSort(array,f,asc){
    for (var i=array.length;i;){
      var o = array[--i];
      array[i] = [].concat(f.call(o,o,i),o);
    }
    array.sort(function(a,b){
      for (var i=0,len=a.length;i<len;++i){
        if (a[i]!=b[i]) return a[i]<b[i]?asc?-1:1:1;
      }
      return 0;
    });
    for (var i=array.length;i;){
      array[--i]=array[i][array[i].length-1];
    }
    return array;
  }

function schwartzianSort(array, f, asc) {
  for (var i = array.length; i;) {
    var o = array[--i];
    array[i] = [].concat(f.call(o, o, i), o);
  }
  array.sort(function(a, b) {
    for (var i = 0, len = a.length; i < len; ++i) {
      if (a[i] != b[i]) return a[i] < b[i] ? asc ? -1 : 1 : 1;
    }
    return 0;
  });
  for (var i = array.length; i;) {
    array[--i] = array[i][array[i].length - 1];
  }
  return array;
}

arr = []
arr.push({
  date: new Date(1494434112806)
})
arr.push({
  date: new Date(1494434118181)
})
arr.push({
  date: new Date(1494434127341)
})

console.log(JSON.stringify(arr));

arr = schwartzianSort(arr, function(o) {
  return o.date
}, false)
console.log("DESC", JSON.stringify(arr));

arr = schwartzianSort(arr, function(o) {
  return o.date
}, true)
console.log("ASC", JSON.stringify(arr));

Это неверно! Возникла ошибка при возврате [i] & lt; б [я]? ASC? -1: 1: 1;
Переменная asc не работает!
6

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

    return arr;
  }

sortByDate(myArr);

Публиковать ссылки всегда плохая идея. Но это простая проблема эпохи Unix, которую должен знать каждый программист :-) Также следует помнить, что на 32-битных машинах в будущем это также не будет выполнено, когда он перевернется.
Имейте в виду, что это не удастся для старых дат. (Прошлый 1970)
Если бы вы могли добавить ссылку, чтобы понять эту проблему, это было бы полезно.
2

ссылка на сайт, он предоставляет функции обратного вызова, которые могут быть переданы в общийsort() функция

0

кто хочет сортировать по дате (британский формат), я использовал следующее:

//Sort by day, then month, then year
for(i=0;i<=2; i++){
    dataCourses.sort(function(a, b){

        a = a.lastAccessed.split("/");
        b = b.lastAccessed.split("/");

        return a[i]>b[i] ? -1 : a[i]<b[i] ? 1 : 0;
    }); 
}
3

так как некоторые пользователи могут не решить, как инвертировать этот метод сортировки.

Чтобы отсортировать по «прибывающему», мы можем просто поменять & amp; б, вот так:

your_array.sort ( (a, b) => {
      return new Date(a.DateTime) - new Date(b.DateTime);
});

Заметить, чтоa теперь на левой стороне, иb справа,: D!

56

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;
});
7

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'));

Похожие вопросы