计算并显示日期为'secs ago','mins ago','hours ago'等

Qua*_*uad 2 php mysql date

我有一个小的自定义博客类型的东西,并希望显示评论旁边发布的日期.

我想以下列格式进行:

23周前
发布了43分钟前
发布于1小时前发布于1天前
发布
在2周前
...可能不会比这更长,因为超过一个月的文章没有显示.

我可以在MySQL中以datetime或timestamp格式存储实际日期...

任何人都知道PHP可以使用的功能吗?我还没找到任何适合的东西.

kia*_*uno 5

您可以使用以下函数并将其命名为format_interval(time() - $saved_timestamp),$saved_timestamp您感兴趣的"事件"的时间戳.(以下代码在GNU通用公共许可证v2或连续版本下获得许可.)

function format_interval($interval, $granularity = 2) {
  $units = array('1 year|@count years' => 31536000, '1 week|@count weeks' => 604800, '1 day|@count days' => 86400, '1 hour|@count hours' => 3600, '1 min|@count min' => 60, '1 sec|@count sec' => 1);
  $output = '';
  foreach ($units as $key => $value) {
    $key = explode('|', $key);
    if ($interval >= $value) {
      $floor = floor($interval / $value);
      $output .= ($output ? ' ' : '') . ($floor == 1 ? $key[0] : str_replace('@count', $floor, $key[1]));
      $interval %= $value;
      $granularity--;
    }

    if ($granularity == 0) {
      break;
    }
  }

  return $output ? $output : '0 sec';
}
Run Code Online (Sandbox Code Playgroud)

$ granularity是要显示的不同单位的数量.例如,format_interval(32745600)会返回"1 year 2 weeks".

我展示的代码是format_interval()Drupal 7 的简化版本,它是在GNU通用公共许可证v2或连续许可证下分发的代码.(另请参阅COPYRIGHT.txt)
我取消了Drupal非常具体的部分,并留下了使用普通PHP函数的代码.