按特殊格式排序日期

时间:2018-04-12 11:51:48

标签: javascript reactjs sorting date

我必须按日期属性对表进行排序,但我的日期如下所示:" 14.01.1970 07:55"。如何以与服务器端不同的格式显示此日期?我该如何对这种类型的日期进行排序?

3 个答案:

答案 0 :(得分:0)

您可以对字符串进行标记并实例化新的Date对象。

var dateStrings = [ "14.01.1970 07:55", "14.01.1972 07:55", "14.01.1971 07:55" ]

function parseDate(dateString) {
  var tokens = dateString.split(/[\.: ]/g);  
  var date   = parseInt(tokens[0], 10);
  var month  = parseInt(tokens[1], 10) - 1;
  var year   = parseInt(tokens[2], 10);
  var hour   = parseInt(tokens[3], 10);
  var minute = parseInt(tokens[4], 10);

  return new Date(year, month, date, hour, minute);
}

// Zulu time 7 hours + timezone offset
console.log(dateStrings.map(parseDate).sort((a, b) => a > b)) 
.as-console-wrapper { top: 0; max-height: 100% !important; }

答案 1 :(得分:0)

只需包含moment.js即可轻松格式化:https://momentjs.com/

例如,打包时间戳moment(yourtimestamp, 'DD.MM.YYYY HH:mm') 并格式化您喜欢的内容,只需.format(yourformat)

像这样:

moment('14.01.1970 07:55', 'DD.MM.YYYY HH:mm').format('YYYY MM DD')

您可以通过创建unix时间戳数组

对它们进行排序
moment('12.02.1980 08:55', 'DD.MM.YYYY HH:mm').format('X')

const array = [319186500, 319182900];

array.sort()

如果你有lodash,也许_.sortBy

答案 2 :(得分:-1)

以下是我将如何使用Javascript(未经测试的代码警报):

// STEP : 1 sample Input
var input = ["01.01.1970 07:55", "06.06.1970 08:55", "03.03.1970 07:55"];

function convertToDateObj(date_string){
    // 14.01.1970 07:55
    date_string = date_string.split('.');
    // [ 0 => 01, 1 => 14, 2 => 1970 07:55 ]
    temp = date_string[0]; date_string[0] = date_string[1]; date_string[1] = date_string[0];
    // 01/14/1970 07:55
    date_string = date_string.join("/");
    // 1970-01-14T02:25:00.000Z
    return new Date(Date.parse(date_string));
}

// STEP : 2 convert to date Objects
var dateObjects = [];
for(var i=0; i<input.length; i++){
   dateObjects[i] = convertToDateObj(input[i]);
}

// STEP : 3 sort them
dateObjects.sort(function(date1, date2){
 if (date1 < date2) {
    return -1;
 } else if (date1 == date2) {
    return 0;
 } else {
    return 1;
 }
})

// your output:
console.log(dateObjects)