页面定时器

202 阅读1分钟

项目中需要获取服务器时间和返回数据中的一个时间进行对比,如果在那个时间前10分钟,就要开启定时器,然而定时器开始后,偶尔会隔秒刷新。

countdown(timestamp) {

  var diff = this.web_time * 1000 - new Date().getTime();
  let timer = setInterval(function() {
    let nowTime = new Date();
    let endTime = new Date(timestamp * 1000);
    let t = endTime.getTime() - (nowTime.getTime() + diff);
    if (t > 0) {
      let day = Math.floor(t / 86400000);
      let hour = Math.floor((t / 3600000) % 24);
      let min = Math.floor((t / 60000) % 60);
      let sec = Math.floor((t / 1000) % 60);
      hour = hour < 10 ? '0' + hour : hour;
      min = min < 10 ? '0' + min : min;
      sec = sec < 10 ? '0' + sec : sec;
      if (date > 0) {
        format = '${day}天${hour}小时${min}分${sec}秒';
      }
      if (date <= 0 && hour > 0) {
        format = '${hour}小时${min}分${sec}秒';
      }
      if (date <= 0 && hour <= 0) {
        format = '${min}分${sec}秒';
      }
    } else {
      clearInterval(timer);
    }
  }, 1000);
}