js计时器的问题以及优化倒计时

最近忙于一个预定会议的小程序,哎 正好最近因为运动量大导致膝盖有些受伤 跑不了步 学习成为了我唯一能做的事情 😃。。。。 需求里面有一些会议到期倒计时的功能,但是前端的倒计时是存在毫秒误差的 因此想到了购物秒杀的对策,再此总结一下🧐

一、setInterval

  1. 我们使用倒计时的时候尽量减少使用setInterval 因为setInterval会无视报错 一直执行 如下代码
setInterval(() => {
      try {
        cnosole.log('是console')
      } catch (e) {
        console.log('错误了')
      }
     
    }, 1000);
    
  1. setInterval里面每次fn执行时间都很长,但下一次并不是等上一次执行完了再过特定时间才开始执行的,实际上早就已经等在队列里了。在fn被阻塞的时候,setInterval仍然在组织将来对回调函数的调用。 因此,当第一次fn函数调用结束时,已经有多次函数调用在等待执行,导致你的进程塞满了一堆ajax请求等待执行

我们最好使用setTimeout来控制倒计时

  setTimeToReStart = (time) => {
    const countTime = 10; // 倒计时秒数
    this.showSeconds = 10;
    this.start = Date.now();
    if( this.showSeconds >= 0) {
      this.inspectionShowTimer = setTimeout(this.countDownStart, 1000)
    }
  }

  countDownStart = (start) => {
    const checkedTime = parseInt((Date.now() - this.start) / 1000, 10);
    console.log(checkedTime, '/checkedTime');
     if(checkedTime >= this.showSeconds) {
      this.clearTimer('inspectionShowTimer');
      this.setState({ inspectionShowTime: checkedTime });
      console.log('完成');}
     else {
      this.inspectionShowTimer = setTimeout(this.countDownStart, 1000)

     }
        
  }

二、setInterval定时器存在的隐患

无法保证在特定时间就会执行 倒计时就不会很准确,需要使用setTimeout控制时间

var start = new Date().getTime(); 
var count = 0; 
 
//定时器测试
setInterval(function(){ 
     count++; 
     console.log( new Date().getTime() - (start + count * 1000)); 
},1000);

正常逻辑是输出一堆0,实际上输出却不是这样

实际输出的值

因此我们要优化的几点

  • 缩短下一个定时器的时间以便缩短进程阻塞造成的执行延迟
  • 从服务端获取倒计时的秒数
    var  interval = 1000,
       ms = 50000,  //从服务器和活动开始时间计算出的时间差,这里测试用50000ms
       count = 0,
       startTime = new Date().getTime();
       if( ms >= 0){
         var timeCounter = setTimeout(countDownStart,interval);                  
       }
 
     function countDownStart(){
       count++;
       var diff = new Date().getTime() - (startTime + count * interval);
       var nextTime = interval - diff;
      
       if (nextTime < 0) { nextTime = 0 };
       ms -= interval;
       console.log(下一个进程在:" + nextTime + "ms后,倒计时:" + ms + "ms");
       if(ms >= 0){
          timeCounter = setTimeout(countDownStart,nextTime)
       } else {
            clearTimeout(timeCounter); 
       }
 }
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,847评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,208评论 1 292
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,587评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,942评论 0 205
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,332评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,587评论 1 218
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,853评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,568评论 0 198
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,273评论 1 242
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,542评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,033评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,373评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,031评论 3 236
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,073评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,830评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,628评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,537评论 2 269