JavaScript Luxon GMT 时间到区域设置



我在格林威治标准时间区域的数据库中有一个时间戳。如何根据用户时区显示时间?目前我有这样的时间

return luxon.DateTime.fromSQL(created_at).setZone('local');

它以 gtm 为单位返回时间。

一个更简洁的处理方法是告诉解析器时间以 GMT 表示:

DateTime.fromSQL(current_time, {zone: "utc"}).toLocal()

为了进一步解释这一点,您的原文中发生的事情是,时间字符串应该被解释为格林威治标准时间,但 Luxon 不知道这一点。因此,它将字符串解释为本地时间,这与偏移量所指的时间不同。但是,如果Luxon知道"这是以格林威治标准时间表示的",那么它将首先获得正确的时间。

使用此方法解决的问题:

let offset = - (new Date().getTimezoneOffset() / 60);
return luxon.DateTime.fromSQL(created_at).plus({hours: offset}).toLocaleString(luxon.DateTime.TIME_SIMPLE)

最新更新