javascript - jQuery 倒数计时器不倒计时

标签 javascript jquery timer countdown

我正在尝试使用 jQuery 实现倒数计时器。我有一个结束时间,计时器应该从它开始倒计时,直到当前时间与它相同。

我从使用 PHP 获取的 Web 服务获取结束时间,我得到的结束时间看起来像这样 2015-07-15 17:29:31

我的实际代码行是这样的

var then=<?php echo $server_response; ?>;

为了便于理解,我在 fiddle 中进行了更改

var then='2015-07-15 17:29:31';

这是 JavaScript 代码:

var timer;
var then='2015-07-15 17:29:31';
var now = new Date();
//now.setDate(now.getDate() + 7); 

var compareDate=then.getDate()-now.getDate();
timer = setInterval(function() {
  timeBetweenDates(compareDate);
}, 1000);

function timeBetweenDates(toDate) {
  var dateEntered = toDate;
  var now = new Date();
  var difference = dateEntered.getTime() - now.getTime();

  if (difference <= 0) {

    // Timer done
    clearInterval(timer);

  } else {

    var seconds = Math.floor(difference / 1000);
    var minutes = Math.floor(seconds / 60);
    var hours = Math.floor(minutes / 60);
    var days = Math.floor(hours / 24);

    hours %= 24;
    minutes %= 60;
    seconds %= 60;

    $("#days").text(days);
    $("#hours").text(hours);
    $("#minutes").text(minutes);
    $("#seconds").text(seconds);
  }
}

HTML

<div id="timer">
  <span id="days"></span>days
  <span id="hours"></span>hours
  <span id="minutes"></span>minutes
  <span id="seconds"></span>seconds
</div>

Fiddle

最佳答案

获取date从字符串使用 new Date(date)

查看更改:

var compareDate = new Date(then) - now.getDate();
//                ^^^^^^^^^^^^^^ instead of then.getDate()

timeBetweenDates()

var dateEntered = new Date(toDate);
//                ^^^^^^^^^^^^^^^^^ Parse to date instead of using it as it is

Demo

编辑

同时更改您从服务器获取日期的方式。 用引号括起来。

var then = '<?php echo $server_response; ?>'; // String

关于javascript - jQuery 倒数计时器不倒计时,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31379559/

相关文章:

javascript - child.remove() 和 parent.removeChild(child) 有什么区别?

jquery - 响应式表格仅适用于 Firefox

java - 按下后退按钮时计时器不会关闭。按下按钮时强制关闭错误

javascript - 除一个元素外单击时切换

javascript - EXT JS 中的依赖字段

javascript - Canvas 游戏中的图像闪烁

javascript - 第一次点击后点击谷歌地图标记不会打开信息窗口

jquery - Javascript - 在隐藏字段中存储对象数组

java - 我在 Timer 类中找不到 start() 方法

Java 变色图形与定时器