私は長い間、time ago
関数で苦労してきました。基本的に私は投稿/コメントを日付timestamp
のmysqlデータベースに保存します。後で、追加時間を前に表示したいとします。例えば、53 minutes ago
です。PHP時間前(間違った時間を返す)
私はユーザーのタイムゾーンをmysql dbに保存していますが、このtime ago
関数をユーザーのタイムゾーンを使用して表示したいとします。
しかし、私の関数は間違った値を返します。例えば、私はUTC + 2で、私の国では11:54です。新しい投稿を追加してdbをチェックすると、投稿された時間は11:54ですが、前に(10秒前にする必要があります)時間を表示したい場合は1 hour, 59 minutes, 50 seconds ago
と表示され、1 hour, 56 minutes, 26 seconds ago
のようになります。
タイムゾーン機能に
if(isset($userRow['timezone'])) {
date_default_timezone_set($userRow['timezone']);
}elseif(isset($_COOKIE['timeZone'])) {
date_default_timezone_set($_COOKIE['timeZone']);
}
コールを取得するには、機能TIME_ELAPSED
<?php echo $user->time_elapsed($datevariable); ?>
TIME_ELAPSED機能
function time_elapsed($datetime, $full = 7) {
$now = new DateTime;
$ago = new DateTime($datetime);
$diff = $now->diff($ago);
echo "</br>";
echo "echo db timestamp for test: ";
echo $datetime;
echo "</br>";
$diff->w = floor($diff->d/7);
$diff->d -= $diff->w * 7;
$string = array(
'y' => 'year',
'm' => 'month',
'w' => 'week',
'd' => 'day',
'h' => 'hour',
'i' => 'minute',
's' => 'second',
);
foreach ($string as $k => &$v) {
if ($diff->$k) {
$v = $diff->$k . ' ' . $v . ($diff->$k > 1 ? 's' : '');
} else {
unset($string[$k]);
}
}
if (!$full) $string = array_slice($string, 0, 1);
return $string ? implode(', ', $string) . ' ago' : 'just now';
}
あなたは常にUTCにすべてを変換して、共通の時間帯に基づいて、時間の数学をやってより安全になるだろう。間違いなくすべてをUTCに保管してください。これにより、サーバーとユーザーのタイムゾーンに関するあらゆる種類の問題が回避されます。それをディスプレイからデータを分離するものとして扱います。 – Elin
@GianfrancescoAurecchia多分イタリア語の「fuso orario」は英語で「タイムゾーン」になることができます。また、:OPは、PHPコードの修正を求めています。修正はJS oneを使用するべきではありません。同意しますか? –
はい、ありがとう、私の投稿を削除しました –