[英]Date not parsing correct in Javascript
我正在使用插入到我的 PostreSQL 数据库中的时间戳并尝试解析它以变得用户友好,但是我得到了错误的年份?
function toTimestamp(strDate){
var datum = Date.parse(strDate);
return datum/1000;
}
let timestamp = toTimestamp('Sun Jan 19 2020 21:19:40 GMT+0000 (Coordinated Universal Time)');
var d = new Date();
d.setTime(timestamp);
console.log(d.toGMTString()); //Mon, 19 Jan 1970 06:44:28 GMT
我期待Sun, 19 Jan 2020 21:19:40 GMT
的结果
不要将数据除以 1000
看这里
function toTimestamp(strDate){ var datum = Date.parse(strDate); return datum; } let timestamp = toTimestamp('Sun Jan 19 2020 21:19:40 GMT+0000 (Coordinated Universal Time)'); var d = new Date(); d.setTime(timestamp); console.log(d.toGMTString()); // Sun, 19 Jan 2020 21:19:40 GMT
这只是一个计量单位的误差。 Date 期望以毫秒为单位的纪元,但您将基准变量除以 1000,将其转换为秒。 这导致了差异,可以通过删除除以 1000 步来解决。
toTimestamp 然后变成:
function toTimestamp(strDate){
return Date.parse(strDate);
}
仅使用datum
而不是datum/1000
除了这个你的代码工作正常
function toTimestamp(strDate){ var datum = Date.parse(strDate); return datum; //return Date.parse(strDate); } let timestamp = toTimestamp('Sun Jan 19 2020 21:19:40 GMT+0000 (Coordinated Universal Time)'); var d = new Date(); d.setTime(timestamp); console.log(d.toGMTString()); //Mon, 19 Jan 1970 06:44:28 GMT
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.