JS或者PHP的倒计时程序代码
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JS或者PHP的倒计时程序代码相关的知识,希望对你有一定的参考价值。
1、规则1:0点—10点显示“距离抢购还剩下”“时”“分”“秒”。
2、规则2:10点—20点显示“抢购已持续”“时”“分”“秒”
3、规则3:20点-24点显示“今日抢购已结束,感谢您的关注”。
想要的输入是这样的:
<p class="tips">文字提示代码</p>
<p><span class="h">小时数字</span>秒</p>
<p><span class="m">分钟数字</span>秒</p>
<p><span class="s">秒数字</span>秒</p>
之所以把文字提示和各种数字分开,是觉得在调用的时候方便。希望有高手路过可以支个招。谢谢了。大概就是我要表达的意思。
<p><span class="h" id="h"></span>时</p>
<p><span class="m" id="m"></span>分</p>
<p><span class="s" id="s"></span>秒</p>
<script type="text/javascript">
<!--
setInterval(
function()
var date = new Date();
hours = date.getHours();
minutes = date.getMinutes();
seconds = date.getSeconds();
if(hours>=0 && hours<10)
document.getElementById('tips').innerhtml = '距离抢购还剩下';
document.getElementById('h').innerHTML = (9-hours);
document.getElementById('m').innerHTML = seconds==0? (60-minutes) : (59-minutes);
document.getElementById('s').innerHTML = seconds==0? 0 : (60-seconds);
else if(hours>=10 && hours<20)
document.getElementById('tips').innerHTML = '抢购已持续';
document.getElementById('h').innerHTML = (hours-10);
document.getElementById('m').innerHTML = minutes;
document.getElementById('s').innerHTML = seconds;
else
document.getElementById('tips').innerHTML = '今日抢购已结束,感谢您的关注。';
document.getElementById('h').innerHTML = '';
document.getElementById('m').innerHTML = '';
document.getElementById('s').innerHTML = '';
,
1000);
-->
</script>追问
请教下,如何让小于10的数字前多个0,例如 6:8:20 显示为 06:08:20
追答
时
分
秒
=0 && hours=10 && hours10? c : '0'+c;
-->
http://www.w3school.com.cn/php/php_ref_date.asp
请高手设计一个PHP倒计时代码,感激不尽
【PHP倒计时代码要求如下】:
1、要求获取服务器时间,不受本地时间和时区的影响
2、要求秒钟跳动,数字减少的方式跳动
3、直到当倒计时时间为00:00:00时,代码将自动重新计算,永不间断。
活动开始时间:年——月——日(服务器日期 - 6)
活动结束时间:年——月——日(服务器日期 + 1)
距结束还剩余:天——时——分——钟(服务器时间 + 24)(然后秒钟跳动倒计时)(超过晚上00:00后,代码不刷新,继续到计时。除非遇到剩余时间为0天0时0分0秒后,代码将重新计算。如此循环)
-----------------------------------------------------------------------
【举个例子】:
假如服务器时间是 2014-8-9 08:30:07
那么网页显示为:
活动开始时间:2014年8月3日
活动结束时间:2014年8月10日
距活动结束 还有1天15小时27分20秒 结束(秒钟不停的在减少)
(当剩余时间为0天0时0分0秒后,代码将自动更新)
-----------------------------------------------------------------------
最后,感激不尽。我对php一窍不通,只懂一点简单的html代码,请将完整的PHP代码复制给我,有注释最好,方便我自己修改,谢谢了!
-----------------------------------------------------------------------
如果很麻烦需要牺牲功能的话,可以把【遇到0天0时0分0秒后代码自动更新】这个功能去掉。因为好像也没有人会把一个网页打开24小时不关闭的。
<?php
date_default_timezone_set('Asia/Shanghai');
echo date("Y-m-d",mktime(date("H",time()),date("i",time()),date("s",time()),date("m",time()),date("d",time())-6,date("Y",time()))).'|'.date("Y-m-d",mktime(date("H",time()),date("i",time()),date("s",time()),date("m",time()),date("d",time())+1,date("Y",time())));
html文件名 ajax_clock.html 内容为
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
活动开始时间<div id="start"></div>
<br />
活动结束时间<div id="end"></div>
<br />
现在还剩下<div id="expire"></div>
<br />
<input type="button" id="ok" name="ok" value="重新开始" onclick="resetClock()" />
<script type="text/javascript">
var url="ajax_clock.php?sid="+Math.random();
var xmlHttp;
function myClock()
xmlHttp=getXMLObject();
xmlHttp.open('GET',url);
xmlHttp.onreadystatechange=handleStateChange;//这一句最为关键,是ajax异步通讯的关键点
xmlHttp.send();
window.setTimeout(myClock,1000);
function handleStateChange()
if(xmlHttp.readyState == 4 && xmlHttp.status == 200)
$('start').innerHTML=xmlHttp.responseText;
window.setTimeout(myClock,1000);
function getXMLObject()
var xmlHttp;
try
xmlHttp=new ActiveXObject('MSXML2.XMLHTTP.3.0');//IE
catch(e)
try
xmlHttp=new XMLHttpRequest();//firefox
catch(e)
alert('不能正常创建xmlhttp对象');
return xmlHttp;
function $(obj_name)
return document.getElementById(obj_name);
</script>追问
你好,我有二个问题。第1个问题是:这个代码是否没有复制完整呢,我测试的时候只有显示了日期,没有出现时间。第2个问题是这个代码能否放到一个文件里面呢(如果需要牺牲功能的话,我宁愿把0天0时0分0秒后代码将自动更新这个功能去掉也行。因为也没有人会把一个网页打开24小时不关闭的)。谢谢你啦,盼回复!
追答可以做到一个文件里。是的,我只是写了一个演示代码。您如果要完整,我下课后给您一个
追问恩好非常谢谢,等我你的代码啦,感激不尽哦!!!
追答效果图:
完整代码:文件名为 ajax_clock.php
<?php
date_default_timezone_set('Asia/Shanghai');
$now=time();
//开始时间
$start=date("Y-m-d",mktime(date("H",$now),date("i",$now),date("s",$now),date("m",$now),date("d",$now)-6,date("Y",$now)));
//结束时间
$end=date("Y-m-d",mktime(date("H",$now),date("i",$now),date("s",$now),date("m",$now),date("d",$now)+1,date("Y",$now)));
//倒计时时间
if(isset($_GET['action']) and $_GET['action']=='ajax')
$now=$_GET['now'];
$now=$now+24*60*60;
$time=time();
$span=$now-$time;
//3670/60
$hour=intval($span/60/60);
$minute=intval(($span-$hour*60*60)/60);
$second=($span-$hour*60*60)-$minute*60;
$expire="0天".$hour."小时".$minute."分".$second."秒";
//输出
echo $expire;
exit();
?>
晕,提示字数超出最大允许值,我放在一个文中件。文件名为ajax_clock.php
活动倒计时效果PHP代码如下:
PS:仅供参考
date_default_timezone_set("Asia/Shanghai");
$time1=time();
$time2=mktime(23,0,0,11,20,2017);
$time3=$time2-$time1;
$day=($time3-($time3%(24*3600)))/(24*3600);
$hour=($time3%(24*3600)-(($time3%(24*3600))%3600))/3600;
$minute=((($time3%(24*3600))%3600)-((($time3%(24*3600))%3600)%60))/60;
$second=($time3%(24*3600)%3600)%60;
参考技术B PHP程序是需要触发的,哪怕你写成死循环到达一定时间也会因为超时被强制结束掉的,最好将倒计时用放在其他程序执行,例如:windows 的计划任务,linux的脚本程序,让web浏览器定时刷新等,然后去触发PHP程序处理逻辑部分的功能 参考技术C 武将 关羽、张飞、马超、黄忠、赵云、魏延、关平、周仓、关兴、张苞、陈到、李严、姜维、廖化、马谡、马岱、陈式、雷铜、吴兰、王平、任夔、张翼、马忠、张南、冯习、傅佥孙吴 文臣 陆逊、张昭、张紘、鲁肃、虞翻、顾雍、诸葛谨、诸葛恪、陆凯、骆统、周鲂 参考技术D 这个效果需要在客户端实现。PHP 实现不了这样的效果。
试试用 JS
以上是关于JS或者PHP的倒计时程序代码的主要内容,如果未能解决你的问题,请参考以下文章