我有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时间戳.通过这种方式,您可以减少时区问题.