我有一个脚本,其格式为:
获取日期/时间2017-06-15 21:00
然后将其转换为本地时间并显示为:
Thu Jun 15 2017 17:00:00 GMT-0400 (Eastern Daylight Time)
脚本:
$(document).ready(function() {
$('.plg-date > .fabrikElement > div').each(function() {
var date = $(this).text();
var newdate = new Date(date + " UTC");
console.log(newdate);
$(this).text(newdate.toString());
})
})
我如何格式化toString以便输出是这样的?
Thu Jun 15 2017 5:00:00 PM Eastern Daylight Time
答案 0 :(得分:2)
您必须自己解析它。有些库可以做到这一点(Stack Overflow规则建议不要提出建议,但是如果你有Google" javascript日期格式库"有点你会找到它们),但是如果你想做的话使用纯JavaScript,你只需要自己构建字符串。
由于您已经创建了Date
个对象,因此您只有一半。
Date
对象只有数字,因此它不会包含Thu
,Jun
和Eastern Daylight Time
之类的字符串。对于那些,您需要列出可能的值并将数字映射到它们(通常一个简单的数组将起作用)。
对于5:00:00 PM
部分,您可以将小时数(%
)修改为12,然后指定AM
hours < 12
或PM
if {{ 1}}。
hours >= 12
我不会给你完整的JavaScript,因为你应该自己写一下。如果您有任何问题,请再问一个问题。
你也可以使用toLocaleString()
的组合,但它不会做你需要的一切(例如,它没有做12小时的日期格式)。
答案 1 :(得分:1)
如果您可以使用外部库,我会建议使用momentjs:
这一个moment('2017-06-15 21:00').format('ddd MMM DD YYYY h:mm:ss A')
// => "Thu Jun 15 2017 9:00:00 PM"
答案 2 :(得分:0)
使用@James建议使用toLocaleString()
$(document).ready(function() {
$('.plg-date > .fabrikElement > div').each(function() {
if($(this).text().length > 0) {
var date = $(this).text();
var newdate = new Date(date + " UTC");
var options = {
year: 'numeric',
month: 'numeric',
day: 'numeric',
hour: '2-digit',
minute: '2-digit',
timeZoneName: 'short'
}
$(this).text(newdate.toLocaleString('en-US', options));
}
})
})