Javascript格式日期/时间

时间:2014-08-12 23:23:54

标签: javascript date datetime

我需要将日期/时间从 2014-08-20 15:30:00 更改为 08/20/2014 3:30 pm

可以使用javascript的Date对象吗?

5 个答案:

答案 0 :(得分:96)

是的,您可以使用原生javascript 日期() 对象及其方法。

例如,您可以创建一个类似的函数:

function formatDate(date) {
  var hours = date.getHours();
  var minutes = date.getMinutes();
  var ampm = hours >= 12 ? 'pm' : 'am';
  hours = hours % 12;
  hours = hours ? hours : 12; // the hour '0' should be '12'
  minutes = minutes < 10 ? '0'+minutes : minutes;
  var strTime = hours + ':' + minutes + ' ' + ampm;
  return date.getMonth()+1 + "/" + date.getDate() + "/" + date.getFullYear() + "  " + strTime;
}

var d = new Date();
var e = formatDate(d);

alert(e);

并显示上午/下午和正确的时间。

请记住使用 getFullYear()方法而不是getYear(),因为它已被弃用。

DEMO http://jsfiddle.net/a_incarnati/kqo10jLb/4/

答案 1 :(得分:59)

请不要重新发明轮子。有许多开源和&amp;已经存在的COTS解决方案可以解决这个问题。

请查看以下JavaScript库:


演示

我使用下面的Moment.js写了一个单行。您可以在此处查看演示:JSFiddle

moment('2014-08-20 15:30:00').format('MM/DD/YYYY h:mm a'); // 08/20/2014 3:30 pm

答案 2 :(得分:14)

对于日期部分:(月份为0索引,而天数为1索引)

var date = new Date('2014-8-20');
console.log((date.getMonth()+1) + '/' + date.getDate() + '/' +  date.getFullYear());

当你想要创建一个函数来测试不同的情况并进行转换时。

答案 3 :(得分:11)

我认为可以使用本机Date对象上的内置方法可靠地完成。 toLocaleString方法接近,但如果我记得正确,它将无法在IE中正常工作&lt; 10.如果您能够使用库来执行此任务,MomentJS是一个非常棒的库;它使日期和时间的工作变得简单。否则,我认为你必须编写一个基本函数来为你提供你想要的格式。

function formatDate(date) {
    var year = date.getFullYear(),
        month = date.getMonth() + 1, // months are zero indexed
        day = date.getDate(),
        hour = date.getHours(),
        minute = date.getMinutes(),
        second = date.getSeconds(),
        hourFormatted = hour % 12 || 12, // hour returned in 24 hour format
        minuteFormatted = minute < 10 ? "0" + minute : minute,
        morning = hour < 12 ? "am" : "pm";

    return month + "/" + day + "/" + year + " " + hourFormatted + ":" +
            minuteFormatted + morning;
}

答案 4 :(得分:1)

你可以这样做:

function formatAMPM(date) { // This is to display 12 hour format like you asked
  var hours = date.getHours();
  var minutes = date.getMinutes();
  var ampm = hours >= 12 ? 'pm' : 'am';
  hours = hours % 12;
  hours = hours ? hours : 12; // the hour '0' should be '12'
  minutes = minutes < 10 ? '0'+minutes : minutes;
  var strTime = hours + ':' + minutes + ' ' + ampm;
  return strTime;
}

var myDate = new Date();
var displayDate = myDate.getMonth()+ '/' +myDate.getDate()+ '/' +myDate.getFullYear()+ ' ' +formatAMPM(myDate);
console.log(displayDate);

Fiddle