将JavaScript new Date()转换为php DateTime()

我有2个
HTML字段:

<input id="datum" type="date">
<input id="uhrzeit" type="time">

JavaScript的:

var datumUhrzeit = new Date($("#datum").val()+","+$("#uhrzeit").val());
console.log(datumuhrzeit);

 "Tue Aug 18 2015 16:45:00 GMT+0200 (Mitteleuropäische Sommerzeit)"

如何将PHP中的“Tue Aug 18 2015 16:45:00 GMT 0200(MitteleuropäischeSommerzeit)”转换为DateTime,以便将其保存到postgresql?

最佳答案 您可以从Date对象获取unix时间戳,如下所示(
see Date.prototype.getTime)

var timestamp = '@' + Math.round(datumUhrzeit.getTime()/1000);

然后在服务器上发送时只需创建新的datetime对象

$datumUhrzeit = new DateTime($timestamp);

如果您不能使用javascript创建时间戳并直接从表单获取数据,则可以执行以下操作,请记住设置时区:

$datum = $_GET['datum'];
$uhrzeit = $_GET['uhrzeit'];
$datumUhrzeit = DateTime::createFromFormat('Y-m-d H:i:s', $datum . ' ' . $uhrzeit, new DateTimeZone('Europe/Berlin'));

现在,当您将日期保存到数据库并检索它时,您可以将其发回

print $datumUhrzeit->format('U'); // This will print the time as unix timestamp

之后,您将只使用时间戳创建您的javascript日期对象

var datumUhrzeit = new Date(timestamp * 1000); // timestamp from above

如果由于某种原因不想使用unix时间戳,可以使用格式化方法以所需格式打印它.请记住事先设置时区

$datumUhrzeit->setTimezone(new DateTimeZone('Europe/Berlin'));
print $datumUhrzeit->format('Y-m-d H:i:s');

因为javascript不适用于时区我会主张你尽可能使用unix时间戳.通过这种方式,您可以减少时区问题.

点赞