任何人都可以帮忙吗?我有这个脚本,它从可怕的标准日期转换 mysql 时间戳,并以用户友好的方式“大约 2 秒前或大约 1 小时前”。
我的问题是这个。它完美地工作,除了当用户发布内容时,他们发布的最新内容回显“大约 0 年前”没有给出发布时间,并且直到他们在此之后发布其他内容时才会看到时间他们在此之前发布过。
所以我想知道为什么这是因为我无法弄清楚,我希望它在用户发布后立即说“刚刚添加”,然后按照脚本说的内容继续执行 20 秒前、2 分钟前等添加.
一个例子是;
(内容 1)“大约 0 分钟前发布”(内容 2)“大约 8 分钟前发布”(内容 3)“大约 5 小时前发布”
那么内容 1 只会更新另一条内容发布的时间,否则它不会。
所以内容 1 应该说刚刚发布,然后在几秒钟后,发布大约 5 秒前、1 分钟前、5 小时前、7 天前等。
<div class="board-wall-feeds">
<div class="social_header">
<?php echo "$profile[2]" ?>'s News & Updates:
</div>
<?php
$timeline_set = get_timeline();
while ($news = mysql_fetch_array($timeline_set)) {
echo "
<div class=\"news_feeds_board_text\">{$news['content']}
<div class=\"social_footer\">about ".$t.$labels[$i]." ago<a href=\"../../../delete_news_post.php?to=".$news['id']."</div><div class=\"social_clip\"></div></div></a>";
$datetime1 = new DateTime();
$datetime2 = new DateTime ($news['date_added']);
$interval = $datetime1->diff($datetime2);
$mdhms = explode('-',$interval->format('%m-%d-%H-%i-%s'));
$labels = Array(' months', ' days', ' hours', ' minutes', ' seconds');
$i = 0;
foreach($mdhms as $t){
if($t > 0) break;
$i+=1;
}
} ?>
</div>