Wednesday, 1 May 2019

javascript - How to sort an array by a date property



Say I have an array of a few objects:



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


How can I sort this array by the date element in order from the date closest to the current date and time down? Keep in mind that the array may have many objects, but for the sake of simplicity I used 2.




Would I use the sort function and a custom comparator?



UPDATE:



In my specific case, I wanted the dates arranged from the most recent to the oldest. It ended up that I had to reverse the simple function's logic as so:



array.sort(function(a, b) {
a = new Date(a.dateModified);
b = new Date(b.dateModified);

return a>b ? -1 : a});


This sorts the dates from the most recent.


Answer



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


Or more tersely:



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



Generic, Powerful Answer



Define a custom non-enumerable sortBy function using a Schwartzian transform on all arrays :



(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 if (a[i]!=b[i]) return a[i] }

return 0;
});
for (var i=this.length;i;){
this[--i]=this[i][this[i].length-1];
}
return this;
}
})();



Use it like so:



array.sortBy(function(o){ return o.date });


If your date is not directly comparable, make a comparable date out of it, e.g.



array.sortBy(function(o){ return new Date( o.date ) });



You can also use this to sort by multiple criteria if you return an array of values:



// 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 for more details.


No comments:

Post a Comment

php - file_get_contents shows unexpected output while reading a file

I want to output an inline jpg image as a base64 encoded string, however when I do this : $contents = file_get_contents($filename); print ...