带有js和php的步行(tic-toc)时钟

时间:2018-09-09 22:51:05

标签: javascript php jquery time clock

在javascript和php上有一个带有“ walkin”时钟的脚本(我需要服务器端时间-这很重要),但是它停止了,直到刷新页面才开始计数。我做错了,请帮忙。谢谢。

<?php $Hour = date("H");
$Minute = date("i");
$Second = date("s");
$Day = date("d");
$Month = date("m"); ?>

<script type="text/javascript">
function clock() {
var d = new Date();
var month_num = d.getMonth();
var day = d.getDate();
var hours = <?php echo $Hour;?>;
var minutes = <?php echo $Minute;?>;
var seconds = <?php echo $Second?>;

month=new Array("января", "февраля", "марта", "апреля", "мая", "июня", "июля", "августа", "сентября", "октября", "ноября", "декабря");

if (day <= 9) day = "0" + day;
if (hours <= 9) hours = "0" + hours;
if (minutes <= 9) minutes = "0" + minutes;
if (seconds <= 9) seconds = "0" + seconds;

date_time = "Today - " + day + " " + month[month_num] + " " + d.getFullYear() + " y. &nbsp;&nbsp;&nbsp;Now - "+ hours + ":" + minutes + ":" + seconds;

if (document.layers) {
 document.layers.doc_time.document.write(date_time);
 document.layers.doc_time.document.close();
} else document.getElementById("doc_time").innerHTML = date_time;
 setTimeout("clock()", 1000);}
</script>

<span id="doc_time">Date & time</span>

<script type="text/javascript">clock();</script>

2 个答案:

答案 0 :(得分:2)

您的问题:

  • PHP在页面上请求相应的日期值。
  • 您将这些值存储到JS
  • 您再次遍历相同的值。因此,循环有效,但值不变。

代替您应该做的事情:

  • 创建一个var D = new Date("<?php echo date('D M d Y H:i:s O');?>");
    功能之外
  • 每次超时,请在初始PHP日期中添加一秒钟
    DATE = PHP:initial + JS:now - JS:initial

function zero(n) { return n > 9 ? n : "0" + n; }
var months = [
  "января", "февраля", "марта", "апреля", "мая", "июня",
  "июля", "августа", "сентября", "октября", "ноября", "декабря",
];
var jsDate = new Date(); // Store JS time

// I'll hardcode a date string for demo purpose:
var phpDate = new Date("Sun Sep 09 2018 23:59:55 +0000");
// You, use this instead:
// var phpDate = new Date("<?php echo date('D M d Y H:i:s O');?>");

function clock() {
  var diff = +new Date() - +jsDate;     // Get seconds difference
  var date = new Date(+phpDate + diff); // Add difference to initial PHP time

  var y = date.getFullYear(),
    M = date.getMonth(),
    d = zero(date.getDate()),
    h = zero(date.getHours()),
    m = zero(date.getMinutes()),
    s = zero(date.getSeconds());

  document.getElementById("doc_time").innerHTML = `
    Дата: ${d} ${months[M]} ${y}. &emsp;
    Время: ${h}:${m}:${s}
  `;

  setTimeout(clock, 1000);
}

clock();
<div id="doc_time"></div>

答案 1 :(得分:1)

该php代码在页面加载时运行一次,因此小时,分钟和秒在Clock()函数的每次调用中始终保持不变。

如果您确实需要执行此操作,则必须每秒使用AJAX请求php脚本以从服务器获取当前时间,但请记住,这些请求将有延迟,并且如果有多个用户,还可能给服务器带来巨大负担同时打开页面。