解析为毫秒更改日期

时间:2015-02-02 17:11:25

标签: javascript date datetime highcharts milliseconds

我在从服务器获取的json中解析日期时遇到问题。日期格式为" YYYY-MM-dd HH-mm-ss CST" (最后是时区),这是第一个条目:

2015-01-06 00:00:00 CST

我使用Highcharts绘制数据,我需要将其解析为毫秒,以便在x轴(datetime)中正确使用。我对javascript中的日期转换不是很熟悉,所以我不断得到奇怪的结果(以毫秒为单位的解析值总是错误的,因此将图表绘制在错误的点上)。

//obj['Time'] has the time value received = "2015-01-06 00:00:00 CST"

var fecha=obj['Time'].split(" ")[0].split("-"),
    hora=obj['Time'].split(" ")[1].split(":")[0];

var from = Date.parse( new Date(fecha[0], fecha[1], fecha[2], hora) );

所以,我尝试过以下方法: 1)直接解析对象['时间']。 2)使用"手动分割输入日期"中的显式值创建一个新的日期对象(存储在'来自'变量中)并解析它。

console.log("Original: " + obj['Time'] );
console.log("1) " + Date.parse(obj['Time']));
console.log("2) " + from);

console.log("Response 1: " + new Date( Date.parse(obj['Time']) ) );
console.log("Response 2: " + new Date( from ) );

结果如下:

Original: 2015-01-06 00:00:00 CST
1) 1420524000000
2) 1423177200000

Response 1: Tue Jan 06 2015 07:00:00 GMT+0100 (CET)
Response 2: Fri Feb 06 2015 00:00:00 GMT+0100 (CET)    

我相信新的Date()正在使用我的本地时区并进行转换,因为该值的偏移量为1小时(GMT + 0100 ???)...所以一切都有"偏移"不应该在那里。也许有人可以让我了解解析这个问题的正确方法:)

谢谢!

注意:我不需要在图表中显示时区,我只需要具有正确的日期时间值。

另外,我在创建新Date对象时意识到了当月的0索引,这就是为什么它显示的是2月而不是Jan,但它仍然不正确修复

1 个答案:

答案 0 :(得分:0)

var date = "2015-01-06 00:00:00 CST".replace(/-/g, "/");
var orgDate = new Date(date);
var dateParsed = Date.parse(orgDate); //parse to timestamp. (In milliseconds)

document.write("Timestamp CST: " + dateParsed);
document.write("<br />");
document.write("<br />"); 
var dateToUTC = new Date(dateParsed);

document.write("UTC/GMT: " + dateToUTC.toUTCString());
document.write("<br />");
document.write("Local: " + dateToUTC.toString());
var timeStringUTC = Date.parse(new Date(dateToUTC.toUTCString()));
document.write("<br />"); 
document.write("<br />"); 

var UTCthen = orgDate.getUTCFullYear()+"-"+(parseInt(orgDate.getUTCMonth())+1 < 10 ? "0"+(parseInt(orgDate.getUTCMonth())+1) : orgDate.getUTCMonth()+1) + "-" + (orgDate.getUTCDate() < 10 ? "0"+orgDate.getUTCDate() : orgDate.getUTCDate())+"T00:00:00.000Z"
document.write("Timestamp UTC: " + Date.parse(UTCthen) );
document.write("<br />");   
document.write("Difference (milliseconds): " + (dateParsed - Date.parse(UTCthen)) + " // = 6 hours");  //6 hours

不要通过拆分进行解析。只需用/替换短划线即可。这将使其成为Date.parse的有效日期。正如您在片段中看到的那样。日期是在 CST 时间内发送的,转换为 UTC 表示我们实际上早上六点在伦敦。该示例还显示了它们之间的毫秒差异。我将解析的日期转换回它的原始UTC时间戳。这是在这一行完成的:

 var UTCthen = orgDate.getUTCFullYear()+"-"+(parseInt(orgDate.getUTCMonth())+1 < 10 ? "0"+(parseInt(orgDate.getUTCMonth())+1) : orgDate.getUTCMonth()+1) + "-" + (orgDate.getUTCDate() < 10 ? "0"+orgDate.getUTCDate() : orgDate.getUTCDate())+"T00:00:00.000Z";

此行返回UTC日期,并在“T00:00:00.000Z”之后追加时间,强制Date.parse认为这是使用Z(祖鲁语)的ISO字符串是GMT / UTC时间。

因此,在Date.parse上使用UTCthen可以获得时间戳的规范化版本。