将存储在 mysql(utc 格式)中的 momentjs 日期时间格式化为本地日期时间

Format momentjs datetime stored in mysql (utc format) to Local DateTime

我在 table 中有一个名为 registerdate 的列,在 mysql 中有一个数据时间类型。

假设现在时间是当地时间“2015-10-10 06:00:00”。

我在数据库中存储 UTC 时间,因此它将转换为“2015-10-10 00:30:00”,因为当地时间是格林威治标准时间 +530。所以正确的时间存储在数据库中。

如何在检索时将注册时间转换为本地时间。

这是我在将日期时间保存到 db 之前的转换方式

moment.utc(new Date()).format("YYYY-MM-DD HH:mm:ss")

这就是我正在尝试将其转换回当地时间的内容。

moment.utc(registerdate, "YYYY-MM-DD HH:mm:ss").local().format("HH:mm:ss")

这不会更改保存日期并呈现与存储在数据库中相同的日期。

第二种方法:它进一步减去 5:30 小时而不是增加它。

moment.utc(_obj[i].StartTime).format("HH:mm:ss")

我哪一步做错了

我不认为使用 JavaScript 在 MySQL 中保存日期时间是个好主意。我认为最好使用 MySQL 函数 UTC_TIMESTAMP()。例如:

INSERT INTO `ITEMS` (`name`, `date_add`) VALUES ('item name', UTC_TIMESTAMP());

现在,当您从 MySQL 检索 UTC 日期时间时,您可以将其转换为 Moment 对象,如下所示:

var utc = moment.utc(MYSQL_DATETIME, 'YYYY-MM-DD HH:mm:ss');
var local = utc.local();
// var local = moment.utc(MYSQL_DATETIME, 'YYYY-MM-DD HH:mm:ss').local();
console.log( local.format("HH:mm:ss") );   // 15:54:31
console.log( local.fromNow() );            // a minute ago   

我没有发现您的代码有任何问题。也许是应用程序方面的问题 (PHP?)。

另一件事。使用不带参数的方法 utc() 与调用 utc(new Date()) 相同。因此,您可以简单地在转换为 MySQL datetime:

时使用它
//moment.utc(new Date()).format("YYYY-MM-DD HH:mm:ss")
moment.utc().format("YYYY-MM-DD HH:mm:ss")

注意:请原谅我的英语不好。

您可能根本不需要使用 moment。如果来自数据库的日期是有效日期,您需要做的就是

var someDate = new Date("2015-10-10 00:30:00");
$("#content").html(someDate.toString());
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div id="content">
<div>

你会看到这给了你当地时间,因为 JS 假设你给了它当地时间。

你可以在字符串末尾添加"Z"强制JS将输入值假定为UTC时间。当"Z"(Zulu)被添加到一个时间的末尾时,表示该时间为UTC http://www.wikiwand.com/en/ISO_8601#/Time_zone_designators

var someDate = new Date("2015-10-10 00:30:00Z");
$("#content").html(someDate.toString());
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div id="content">
<div>

万一你需要使用时刻 而不是新日期(“2015-10-10 00:30:00Z”) 你可以做 moment("2015-10-10 00:30:00Z") 希望这有帮助