实时功能
Live time function
我已经设置了我的Agotime函数。我只是想知道我应该使用什么方法来让我的时间更新。很多人会说Ajax,但这会是服务器繁重吗?我需要每 5 秒平稳更换一次。
另外我该怎么做?
function Agotime($date)
{
if(empty($date)) {
return "No date provided";
}
$periods = array("second", "minute", "hour", "day", "week", "month", "year", "decade");
$lengths = array("60","60","24","7","4.35","12","10");
$now = time();
$unix_date = strtotime($date);
// check validity of date
if(empty($unix_date)) {
return "Bad date";
}
// is it future date or past date
if($now > $unix_date) {
$difference = $now - $unix_date;
$tense = "ago";
} else {
$difference = $unix_date - $now;
$tense = "from now";
}
for($j = 0; $difference >= $lengths[$j] && $j < count($lengths)-1; $j++) {
$difference /= $lengths[$j];
}
$difference = round($difference);
if($difference != 1) {
$periods[$j].= "s";
}
return "$difference $periods[$j] {$tense}";
}
您可以通过以下两种方式之一实现它。
你可以按照你的建议使用AJAX,并查询你的PHP脚本多久以前。但是,这可能会对请求数量造成很大影响。
你也可以在 Javascript 中实现这个函数,只需在加载时将包含传递时间戳传递给脚本。这样,您就不必对服务器执行任何请求,并且可以保持时间更新。当然,这假设时间戳不会更改。
我个人会选择选项 #2,因为它在 Javascript 中很容易计算,并且避免了大量的网络流量。
最好的选择是传入递增的日期,使用 setTimeout 并每 5 秒触发一次
然后,如果您愿意,可以进行"检查"以确保服务器上的时间与您在浏览器中的时间匹配,请使用每X次更新的ajax调用来"重新同步"日期/时间
相关文章:
- 添加文字和评论功能更新Div
- JavaScript打印功能使日历停止工作
- 使用Facebook live API创建实时视频对象时的隐私设置
- 有任何可能将facebook实时信使整合到一个网站中
- 每当您在选择器内移动鼠标时,悬停功能就会重复
- 如何防止网页加载后自动启动功能
- 除修剪外的其他功能
- 悬停功能触发器
- 使用angularjs向浏览器发送servlet响应(下载功能)
- jQuery+Android.将功能(Touchstart、touchmove)应用于实时加载的内容
- 复制此实时核心功能
- AngularJs 控制器中的实时时钟功能
- 实时功能
- 使用“打开键控”功能进行实时
- jQuery脚本的顺序正确吗?隐藏/显示功能在实时版本中不起作用,但可以作为独立Fiddle使用
- 是否有一种方法来运行jquery.没有任何事件的实时功能
- 为什么实时点击功能自动工作时,它应该只发生在点击
- Javascript .replace()在控制台和实时环境中的功能不同
- Jquery实时输入验证.发布功能
- D3.JS时间序列折线图,具有实时数据、平移和缩放功能