我正在为我的网站制作倒数计时器,但无法让脚本正常工作。脚本的创建者PHP F1无法提供帮助。
问题是:为什么目标日期($targetDate
)变量中的年份没有通过HTML / JavaScript工具?
我正在使用mktime()
功能。无论我是否将实际日期放入最后一个属性位置(年份)或者我是否输入了日期函数(就像我在下面的代码中完成的那样)我只是无法正确显示它前端。
我不是任何方式的PHP / JavaScript大师,所以这可能看起来像是一个真正的noobie问题,但如果有人可以帮助我,我将非常感激!
以下是以下代码的实时实现: http://tripdealio.com/countdown/countdown5.php
以下是代码:
<?php
/* Define your target date here
$targetYear = 2011;
$targetMonth = 09;
$targetDay = 30;
$targetHour = 23;
$targetMinute= 59;
$targetSecond= 59;
End target date definition */
// Define date format
$dateFormat = "Y-m-d H:i:s";
$targetDate = mktime(23,59,59,09,30,date("Y"));
$actualDate = time();
$secondsDiff = $targetDate - $actualDate;
$remainingDay = floor($secondsDiff/60/60/24);
$remainingHour = floor(($secondsDiff-($remainingDay*60*60*24))/60/60);
$remainingMinutes = floor(($secondsDiff-($remainingDay*60*60*24)-($remainingHour*60*60))/60);
$remainingSeconds = floor(($secondsDiff-($remainingDay*60*60*24)-($remainingHour*60*60))-($remainingMinutes*60));
$targetDateDisplay = date($dateFormat,$targetDate);
$actualDateDisplay = date($dateFormat,$actualDate);
?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Max's Countdown System</title>
<link href="style/style.css" rel="stylesheet" type="text/css" />
<script type="text/javascript">
var days = <?php echo $remainingDay; ?>
var hours = <?php echo $remainingHour; ?>
var minutes = <?php echo $remainingMinutes; ?>
var seconds = <?php echo $remainingSeconds; ?>
function setCountDown ()
{
seconds--;
if (seconds < 0){
minutes--;
seconds = 59
}
if (minutes < 0){
hours--;
minutes = 59
}
if (hours < 0){
days--;
hours = 23
}
document.getElementById("remain").innerHTML = days+" days, "+hours+" hours, "+minutes+" minutes, "+seconds+" seconds";
setTimeout ( "setCountDown()", 1000 );
}
</script>
</head>
<body onload="setCountDown();">
<div id="container">
<div id="header"><div id="header_left"></div>
<div id="header_main">Max's Countdown System</div><div id="header_right"></div></div>
<div id="content">
<table class="countTable">
<tr><td>Target date:</td><td><?php echo $targetDateDisplay; ?></td></tr>
<tr><th colspan="2" id="remain"><?php echo "$remainingDay days, $remainingHour hours, $remainingMinutes minutes, $remainingSeconds seconds";?></th></tr>
<tr><td>Actual date:</td><td><?php echo $actualDateDisplay; ?></td></tr>
</table>
</div>
<div id="footer"><a href="http://www.phpf1.com" target="_blank">Powered by PHP F1</a></div>
</div>
</body>
</html>
答案 0 :(得分:1)
我没有看到算法有什么特别的错误,JS代码中只有语法错误(缺少分号)。这是固定代码:
var days = <?php echo $remainingDay; ?>;
var hours = <?php echo $remainingHour; ?>;
var minutes = <?php echo $remainingMinutes; ?>;
var seconds = <?php echo $remainingSeconds; ?>;
function setCountDown ()
{
seconds--;
if (seconds < 0){
minutes--;
seconds = 59;
}
if (minutes < 0){
hours--;
minutes = 59;
}
if (hours < 0){
days--;
hours = 23;
}
document.getElementById("remain").innerHTML = days+" days, "+hours+" hours, "+minutes+" minutes, "+seconds+" seconds";
setTimeout ( "setCountDown()", 1000 );
}
您也可以使用setInterval而不是setTimeout,但这只是一次整容更改。
答案 1 :(得分:1)
您正在使用
计算目标时间$targetDate = mktime(23,59,59,09,30,date("Y"));
// be careful: ↑
但是以0
开头的数字在PHP中被视为八进制;此外,引用documentation:
如果以八进制整数(即8或9)给出无效数字,则忽略该数字的其余部分。
因此09
实际上会被解析为0
,并且mktime
的示例#3显示
任何给定月份的最后一天可以表示为下个月的“0”日,而不是-1天。
因此,第0个月将导致年数减少,此时此刻为2009年。
正如您现在所猜测的那样,解决方案很简单:放弃0
$targetDate = mktime(23,59,59,9,30,2011);
(date("Y")
目前将返回2010年,但根据您的评论,您希望2011年。
顺便说一句,我想你想用setInterval
而不是setTimeout
;见setTimeout or setInterval?