php实现倒计时效果


Posted in PHP onDecember 19, 2015

现在很多的团购网站上都有剩余时间的显示。显示剩余时间可以使用Javascript来实现,但是我们会发现使用Javascript来实现的话不安全,因为Javascript获取的是客户端的时间。比方说,这次团购已经结束了,但是懂技术的访客只要修改他客户端电脑的时间就又显示该商品还可以购买。很明显,这不是我们网站设计的初衷。团购结束了就不可以再购买啦。这里写了一个考试系统剩余时间倒计时的显示代码和大家一起探讨。

实现原理:
PHP获取的是服务器端的时间,我们只要设置考试的开始时间和结束时间及当前时间。如果当前的时间不在我们的考试时间范围内,则显示给考生“当前不在考试时间段!”。如果在考试时间范围内,则获取当前时间,结束时间减掉当前时间就是剩余的时间,将剩余时间格式化输出就是“剩余考试时间:2小时56分32秒”这样的形式。服务器端获得了剩余时间后,我们还要在客户端动态的显示剩余时间的倒计时。这就需要用AJAX来实现了。在开始前大家先熟悉几个函数吧!

PHP函数:
strtotime(); //将任何英文日期转换为时间戳
floor(); //舍去法取整,和int()强制转换相识
json_encode() //对变量进行JSON编码,返回字符串

简单的剩余天数计算:

date_default_timezone_set('Asia/Hong_Kong');
$startDate = '2015-8-11';
$endDate = '2015-8-31';

// 将日期转换为Unix时间戳
$startDateStr = strtotime($startDate);
$endtDateStr = strtotime($endDate);
$total = $endtDateStr-$startDateStr;

$now = strtotime(date('Y-m-d'));
$remain = $endtDateStr-$now;

echo '为期:'.$total/(3600*24).'天<br>';
echo '剩余:'.$remain/(3600*24).'天';

效果:

php实现倒计时效果

简单的剩余时间计算:

date_default_timezone_set('Asia/Hong_Kong');
$startTime = '09:00:00';
$endTime = '18:00:00';

// 将时间转化为unix时间戳
$startTimeStr = strtotime($startTime);
$endTimeStr = strtotime($endTime);
$total = $endTimeStr - $startTimeStr;

$restHours = 1; // 休息1小时

$now = strtotime(date('H:i:s'));
$remain = $endTimeStr - $now;

echo '上班时间:'.($total/3600-$restHours).'小时<br>';
echo '还有:'.floor(($remain/3600)).'小时'.floor($remain/60).'分钟下班';

效果:

php实现倒计时效果

前后端配合实现考试剩余时间:

HTML布局

考试剩余时间:

<span id="hour">00</span>小时<span id="minute">00</span>分<span id="second">00</span>秒

JS脚本

function dealData(id,value){
  var place = document.getElementById(id);
  place.innerHTML = value;
}
window.setInterval(function(){ // 每秒从服务器取一次数据
  var ajax = new Ajax();
  ajax.get("remain_time.php?a="+Math.random(),function(data){
  eval("var dtime = "+data); 
  dealData('hour',dtime.hour);
  dealData('minute',dtime.minute);
  dealData('second',dtime.second);
 });
},1000);

PHP代码:

date_default_timezone_set('PRC');
$start_time = '09:00:00';
$end_time = '18:00:00';
$start_famate_time = strtotime($start_time);//开始时间转化为时间戳
$end_famate_time = strtotime($end_time); //结束时间转化为时间戳
$now_time = time();
if($end_famate_time < $now_time || $start_time > $now_time){
 echo '当前不在考试的时间范围内!';
 exit;
}
$remain_time = $end_famate_time-$now_time; //剩余的秒数
$remain_hour = floor($remain_time/(60*60)); //剩余的小时
$remain_minute = floor(($remain_time - $remain_hour*60*60)/60); //剩余的分钟数
$remain_second = ($remain_time - $remain_hour*60*60 - $remain_minute*60); //剩余的秒数
echo json_encode(array('hour'=>$remain_hour,'minute'=>$remain_minute,'second'=>$remain_second));

以上就是php实现倒计时的关键代码,希望对大家的学习有所帮助。

PHP 相关文章推荐
php SQL之where语句生成器
Mar 24 PHP
浅析php中jsonp的跨域实例
Jun 21 PHP
深入解析fsockopen与pfsockopen的区别
Jul 05 PHP
php过滤所有恶意字符(批量过滤post,get敏感数据)
Mar 18 PHP
php cli换行示例
Apr 22 PHP
PHP+MYSQL实现用户的增删改查
Mar 24 PHP
php+ajax实现无刷新动态加载数据技术
Apr 28 PHP
人脸识别测颜值、测脸龄、测相似度微信接口
Apr 07 PHP
laravel通过创建自定义artisan make命令来新建类文件详解
Aug 17 PHP
php如何利用pecl安装mongodb扩展详解
Jan 09 PHP
PHP Include文件实例讲解
Feb 15 PHP
YII框架页面缓存操作示例
Apr 29 PHP
Thinkphp实现自动验证和自动完成
Dec 19 #PHP
详解WordPress中过滤链接与过滤SQL语句的方法
Dec 18 #PHP
基于ThinkPHP实现批量删除
Dec 18 #PHP
thinkphp实现163、QQ邮箱收发邮件的方法
Dec 18 #PHP
WordPress中注册菜单与调用菜单的方法详解
Dec 18 #PHP
讲解WordPress开发中一些常用的debug技巧
Dec 18 #PHP
详解WordPress中给链接添加查询字符串的方法
Dec 18 #PHP
You might like
网友原创的PHP模板类代码
2008/09/07 PHP
PHP IF ELSE简化/三元一次式的使用
2011/08/22 PHP
PHP连接MongoDB示例代码
2012/09/06 PHP
浅析php面向对象public private protected 访问修饰符
2013/06/30 PHP
php CI框架插入一条或多条sql记录示例
2014/07/29 PHP
WordPress中用于获取文章信息以及分类链接的函数用法
2015/12/18 PHP
JQuery 图片延迟加载并等比缩放插件
2009/11/09 Javascript
javascript for循环设法提高性能
2010/02/24 Javascript
两个JavaScript jsFiddle JSBin在线调试器
2010/03/14 Javascript
jQuery旋转木马式幻灯片轮播特效
2015/12/04 Javascript
深入理解JavaScript函数参数(推荐)
2016/07/26 Javascript
详解XMLHttpRequest(二)响应属性、二进制数据、监测上传下载进度
2016/09/14 Javascript
浅谈Angular.js中使用$watch监听模型变化
2017/01/10 Javascript
基于node.js依赖express解析post请求四种数据格式
2017/02/13 Javascript
JS实现最简单的冒泡排序算法
2017/02/15 Javascript
JavaScript使用链式方法封装jQuery中CSS()方法示例
2017/04/07 jQuery
vue2.0 keep-alive最佳实践
2017/07/06 Javascript
CheckBox多选取值及判断CheckBox选中是否为空的实例
2017/10/31 Javascript
浅谈vue后台管理系统权限控制思考与实践
2018/12/19 Javascript
jQuery实现点击滚动到指定元素上的方法分析
2020/03/19 jQuery
Python的Flask框架中实现简单的登录功能的教程
2015/04/20 Python
Python编程中用close()方法关闭文件的教程
2015/05/24 Python
Python实现Pig Latin小游戏实例代码
2018/02/02 Python
Python 计算任意两向量之间的夹角方法
2019/07/05 Python
德国亚马逊官方网站:Amazon.de
2020/11/15 全球购物
高中微机老师自我鉴定
2014/02/16 职场文书
应届生求职信范文
2014/05/26 职场文书
2014法院干警廉洁警示教育思想汇报
2014/09/13 职场文书
毕业典礼邀请函
2015/01/31 职场文书
社区党员干部承诺书
2015/05/04 职场文书
反腐倡廉影片观后感
2015/06/08 职场文书
焦裕禄纪念馆观后感
2015/06/09 职场文书
单位工作证明范本
2015/06/15 职场文书
2016暑期校本培训心得体会
2016/01/08 职场文书
Oracle创建只读账号的详细步骤
2021/06/07 Oracle
MySQL into_Mysql中replace与replace into用法案例详解
2021/09/14 MySQL