我需要将日期/时间从 2014-08-20 15:30:00 更改为 08/20/2014 3:30 pm
可以使用javascript的Date对象吗?
答案 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(),因为它已被弃用。
答案 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);