php实时倒计时的三种实现方法
1、要有小时分钟秒的实时倒计时的显示。
2、用户端修改日期时间不会影响到倒计时的正常显示(也就是以服务器时间为准)。
其实这和很多考试等系统时间限制功能的要求一样。
解决思路:
1、总不能用ajax每秒都获取服务器时间吧,所以实时倒计时一定要用javascript实现。这很简单,网上一大把的例子。
2、现在问题是解决用户端修改日期时间对我们的显示的影响。解决的办法是计算出用户端的时间和服务器的时间差,这样问题就完全解决了,只需要运行一次php,实时倒计时的时间就和服务器的时间同步了。理论是同步的,但实际测试会有1秒的误差(具体原因就是和网速有关,网速越快,误差就越小),但这决不会影响到我们上面的要求了。
代码1:
<?php
//php的时间是以秒算,js的时间以毫秒算
date_default_timezone_set("Asia/Hong_Kong");//地区
//配置每天的活动时间段
$starttimestr = "09:00:00";
$endtimestr = "18:30:00";
$starttime = strtotime($starttimestr);
$endtime = strtotime($endtimestr);
$nowtime = time();
$lefttime = $endtime-$nowtime;//实际剩下的时间(秒)
?>
代码2,修改了代码1的一些bug:
<?php
//php的时间是以秒算,js的时间以毫秒算
date_default_timezone_set("Asia/Hong_Kong");//地区
//配置每天的活动时间段
$starttimestr = "09:00:00";
$endtimestr = "18:30:00";
$starttime = strtotime($starttimestr);
$endtime = strtotime($endtimestr);
$nowtime = time();
$lefttime = $endtime-$nowtime;//实际剩下的时间(秒)
?>
代码3,思路不同,简单多了:
<?php
//php的时间是以秒算,js的时间以毫秒算
date_default_timezone_set("Asia/Hong_Kong");//地区
//配置每天的活动时间段
$starttimestr = "09:00:00";
$endtimestr = "13:50:00";
$starttime = strtotime($starttimestr);
$endtime = strtotime($endtimestr);
$nowtime = time();
if ($nowtime<$starttime){
die("活动还没开始,活动时间是:{$starttimestr}至{$endtimestr}");
}
$lefttime = $endtime-$nowtime;//实际剩下的时间(秒)
?>