• JavaScript 之 定时器


      JavaScript 里面有两个定时器:setTimeout() 和 setInterval() 。

      区别

        setTimeout():相当于一个定时炸弹,隔一段时间执行,并且只会执行一次就不在执行了。

        setInterval(): 相当于一个闹钟,隔一段时间执行,并且会重复执行。

    一、setTimeout()

      1、设置定时器(倒计时)

        语法格式

    setTimeout(function() {},时间);
    

            这个函数需要两个参数:

          第一个参数是到时间后需要执行的函数,可以是匿名函数,也可以是命名函数;

          第二个参数是时间间隔,单位为毫秒(ms)。

        Demo:

    1 btn.onclick = function() {
    2   setTimeout(function(){
    3        alert("hello world");  
    4     },3000);  
    5 }    

        当点击按钮3秒后,页面弹出 “hello world” 的对话框。

      2、取消定时器(倒计时)

        语法格式

    var  timerId = setTimeout(function(){}, 时间间隔);
    clearTimeout(timerId);
    

        声明定时器时会有一个返回值,是一个整数,即当前这个定时器的 标识

         在执行 clearTimeout() 这个函数时,在里面传入对应的 定时器的标识 即可取消当前的定时器。

    二、setInterval()

      1、设置定时器

        语法格式

    setInterval(function(){},时间间隔);
    

         这个函数需要两个参数:

          第一个参数是到时间后需要执行的函数,可以是匿名函数,也可以是命名函数;

          第二个参数是时间间隔,单位为毫秒(ms)。

      2、取消定时器

         语法格式

    var  timerId = setInterval(function(){}, 时间间隔);
    clearInterval(timerId);
    

          声明定时器时会有一个返回值,是一个整数,即当前这个定时器的 标识

         在执行 clearTimeout() 这个函数时,在里面传入对应的 定时器的标识 即可取消当前的定时器。

        Demo:距离2019年11月11日倒计时

     1  // 结构
     2  <h1 class="title">距离光棍节,还有</h1>
     3   
     4   <div class="time-item">
     5     <span><span id="day">00</span>天</span>
     6     <strong><span id="hour">00</span>时</strong>
     7     <strong><span id="minute">00</span>分</strong>
     8     <strong><span id="second">00</span>秒</strong>
     9   </div>
    10 
    11 <script>
    12     // 目标时间
    13     var endDate = new Date('2019-11-11 0:0:0');
    14     // 获取 span
    15     var spanDay = document.getElementById('day');
    16     var spanHour = document.getElementById('hour');
    17     var spanMinute = document.getElementById('minute');
    18     var spanSecond = document.getElementById('second');
    19 
    20     countdown();
    21     setInterval(countdown, 1000);
    22 
    23     // 倒计时
    24     function countdown() {
    25 
    26       // 计算时间差
    27       // 当前时间
    28       var startDate = new Date();
    29       // 计算两个日期差
    30       var interval = getInterval(startDate, endDate);
    31 
    32       setInnerText(spanDay, interval.day);
    33       setInnerText(spanHour, interval.hour);
    34       setInnerText(spanMinute, interval.minute);
    35       setInnerText(spanSecond, interval.second);
    36 
    37     }
    38     
    39  // 获取两个日期的时间差
    40 function getInterval(start, end) {
    41   // 两个日期对象,相差的毫秒数
    42   var interval = end - start;
    43   // 求 相差的天数/小时数/分钟数/秒数
    44   var day, hour, minute, second;
    45 
    46   // 两个日期对象,相差的秒数
    47   // interval = interval / 1000;
    48   interval /= 1000;
    49 
    50   day = Math.round(interval / 60 / 60 / 24);
    51   hour = Math.round(interval / 60 / 60 % 24);
    52   minute = Math.round(interval / 60 % 60);
    53   second = Math.round(interval % 60);
    54 
    55   return {
    56     day: day,
    57     hour: hour,
    58     minute: minute,
    59     second: second
    60   }
    61 }
    62 
    63 </script>

      

  • 相关阅读:
    [AGC005D] ~K Perm Counting
    [国家集训队]middle
    CF842D Vitya and Strange Lesson
    浅谈脚本化css(三)之方块运动函数
    浅谈脚本化css(二)
    浅谈脚本化css(一)
    滚动条详解及制作(三)
    滚动条详解及制作(二)
    滚动条详解及制作(一)
    javascript定时器详解
  • 原文地址:https://www.cnblogs.com/niujifei/p/11441828.html
Copyright © 2020-2023  润新知