4

我正在使用 Angular 6 进行开发。保存新记录时,我将表单值作为 json 保存在数据库中。如果最终用户想要显示存在记录,我会从 json 数据中填充表单组件。但是我在转换日期值时遇到了麻烦。我无法正确投射我的本地日期。我已经尝试过,但没有奏效:

console.log("string Value",stringValue);
let date = moment(stringValue,"yyyy-mm-ddThh:mm:ss.fffZ");                             
console.log("date",date.format('DD/MM/YYY HH:mm:ss'));

字符串值输出:2019-01-17T21:00:00.000Z

控制台输出实际:日期 18/01/2019 01:00:00

但预期控制台输出:日期 18/01/2019 00:00:00

我试过“YYYY-MM-DDThh:mm:ss.fffZ”但也没有用。

额外的信息

保存数据:

process.data = JSON.stringify(this.form.getRawValue());
save(process);

html(初始):

<p-calendar formControlName="startDate" dateFormat="dd.mm.yy"></p-calendar>
4

2 回答 2

5

您可以使用解析您的'2019-01-17T21:00:00.000Z'输入,moment.utc()因为它代表 UTC 时间

默认情况下,moment 解析并以本地时间显示。

如果要解析或显示 UTC 时刻,可以使用moment.utc()代替moment().

然后使用 . 将其转换为本地时区local()

这是一个现场样本:

const stringValue = '2019-01-17T21:00:00.000Z';
let date = moment.utc(stringValue).local();
console.log("date", date.format('DD/MM/YYYY HH:mm:ss'));
<script src="https://cdnjs.cloudflare.com/ajax/libs/moment.js/2.23.0/moment.min.js"></script>

于 2019-01-18T09:21:03.710 回答
0

moment-timezone 库旨在“解析和显示任何时区的日期”。

要在特定时区构造日期时间对象,请使用:

let now = moment.tz('Europe/Istanbul');

要查看 UTC 值,请使用

now.toISOString()

要查看本地时区值,请使用:

now.format('YYYY-MM-DD HH:mm:ss.SSS');
于 2019-01-18T16:37:06.547 回答