随笔 - 1162  文章 - 0  评论 - 16  阅读 - 59万 

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

  区别

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

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

一、setTimeout()

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

    语法格式

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

        这个函数需要两个参数:

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

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

    Demo:

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

 

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

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

    语法格式

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

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

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

二、setInterval()

  1、设置定时器

    语法格式

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

     这个函数需要两个参数:

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

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

  2、取消定时器

     语法格式

1
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>
复制代码

 

  

 

posted on   格物致知_Tony  阅读(286)  评论(0编辑  收藏  举报
编辑推荐:
· 没有源码,如何修改代码逻辑?
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· .NET Core 托管堆内存泄露/CPU异常的常见思路
阅读排行:
· 微软正式发布.NET 10 Preview 1:开启下一代开发框架新篇章
· C# 集成 DeepSeek 模型实现 AI 私有化(本地部署与 API 调用教程)
· DeepSeek R1 简明指南:架构、训练、本地部署及硬件要求
· 没有源码,如何修改代码逻辑?
· NetPad:一个.NET开源、跨平台的C#编辑器
点击右上角即可分享
微信分享提示

目录导航