1

我有一个带有entity表和users表的数据库。实体表具有created_at和的字段updated_at。users 表有timezone一个默认值为 的字段America/Toronto

在我看来,我可以使用以下代码以我想要的格式输出日期:

$entity->created_at->format('M j, Y \\a\\t g:i A')

现在,如何使用用户表中的时区字段输出日期?就像是 ...

$entity->created_at->format('M j, Y \\a\\t g:i A', Auth::user()->timezone);

我正在寻找一种使用Carbon的简单方法(因为我在 Laravel 中使用 Eloquent,它将上述日期列转换为 Carbon 的实例)。

注意:我只希望在显示日期时更改时区 - 我仍然希望将所有日期存储在数据库中的默认 UTC 时区中。

另外,我在哪里可以找到可以与 Carbon 一起使用的有效时区列表?我想将这些存储在我的数据库中,以便用户可以更改他们的默认时区。

4

1 回答 1

5

您需要使用 Carbon 函数copy()来保持对象上的时区不变。然后您可以将时区设置为您想要的任何内容并“输出”结果。

$entity->created_at->copy()->tz(Auth::user()->timezone)->format('M j, Y \\a\\t g:i A');

至于时区 -它只是 PHP timezones

$tzlist = DateTimeZone::listIdentifiers(DateTimeZone::ALL);
于 2014-05-23T16:08:54.780 回答