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>

  

原文地址:https://www.cnblogs.com/niujifei/p/11441828.html

时间: 2024-10-04 13:17:32

JavaScript 之 定时器的相关文章

JavaScript做定时器

2015-03-28 18:08:52 通过JavaScript做定时器有两种方法: 第一种为不循环定时器:只出现一次,通过window.setTimeout('function_name();',timeout);方法 timeout为毫秒数,意为过timeout后,执行function_name();函数,window可省 <script language='javascript'> //定义一个函数,显示你好信息,要求该函数在页面加载5秒后被调用 function getHello(){

day27—JavaScript实现定时器及其应用案例

转行学开发,代码100天--2018-04-12 JavaScript中定时器有两种,分别是setInterval和setTimeout;其用法如下: 开启: setTimeout("function",time) 设置一个超时对象:延迟执行:只执行一次 setInterval("function",time) 设置一个超时对象:连续执行:重复执行 *上述两种方法,均有返回值,即改定时器对象.该对象可作为关闭对象输入. 关闭: clearTimeout(对象) 清除

&lt;JavaScript&gt; 八. 定时器

1 <!DOCTYPE html> 2 <html> 3 <head> 4 <title></title> 5 <script type="text/javascript"> 6 /* 7 定时器 周期性执行JS代码 8 */ 9 10 // --------------------- 方法 ----------------------- 11 /* 12 1. setInterval(code, millisec

JavaScript中定时器

JavaScript提供定时执行代码的功能,叫做定时器(timer),主要由setTimeout()和setInterval()这两个函数来完成.它们向任务队列添加定时任务. setTimeout() setTimeout函数用来指定某个函数或某段代码,在多少毫秒之后执行.它返回一个整数,表示定时器的编号,以后可以用来取消这个定时器. var timerId = setTimeout(func|code, delay) 上面代码中,setTimeout函数接受两个参数,第一个参数func|cod

JavaScript中定时器问题与解决方法

最近在做用setInterval在做定时器的时候,发现一些问题. 就是一旦定时器中一旦任务执行时间超过定时间隔时间得时候,JavaScript不会等待这次任务执行完毕,重现计算时间间隔,而是到时间间隔一到立马将下次任务加入队列,并且等待该次任务执行完毕后,立马执行,所有定时加载变成循环加载.这是我们所不愿意见到的. setInterval代码: function startFn2() {        var p2 = new AlarmClockByInterval(callBackByTes

JavaScript的定时器是如何工作的

理解JavaScript定时器工作原理对于学习JavaScript非常重要.因为JavaScript是单线程运行的,定时器使用场合少,不是很直观.下面通过三个函数来学习JavaScript如何定义,操作及销毁一个定时器. var id = setTimeout(fn, delay); - 定义一个定时器,在指定时间delay后调用函数fn.函数返回一个唯一的标识ID,如果不需要使用这个定时器可以用这个取消. var id = setInterval(fn, delay);- 类似setTimeo

javascript:定时器

原文章:https://wangdoc.com/javascript/index.html 定时器 JavaScript 提供定时执行代码的功能,叫做定时器(timer),主要由setTimeout()和setInterval()这两个函数来完成.它们向任务队列添加定时任务. setTimeout() setTimeout函数用来指定某个函数或某段代码,在多少毫秒之后执行.它返回一个整数,表示定时器的编号,以后可以用来取消这个定时器. var timerId = setTimeout(func|

Javascript 的定时器 setInterval,setTimeout,clearInterval

今天开通博客.来1个.哇哈哈哈~~ 今天本来想复习BOM的看到定时器也算DOM一种 ?(是这样吗).分享一下 参考源于:八神吻你 http://www.cnblogs.com/lmfeng/archive/2011/06/24/2089237.html 单次定时器即执行 1 //单次定时器即执行 2 3 setInterval(console.log(1),1000); //执行1次 4 5 //------------------------------------ 6 7 var a = f

JavaScript 之 定时器 延迟器

1:setTimeout("function()",time) setTimeout("function()",time) 设置一个超时对象,执行到到该代码时会延迟time/1000秒去执行function函数 2:  setInterval("function()",time) setInterval("function()",time) 设置一个定时对象,执行到该代码时会每隔time/1000秒去执行function函数,