js中两种定时器的设置及清除

https://www.cnblogs.com/Dream2hc/p/web23863.html

https://www.cnblogs.com/wangying731/p/5164780.html

1.循环执行:

var timeid = window.setInterval(“方法名或方法”,“延时”);

window.clearInterval(timeid);

<script type="text/javascript">
  $(document).ready(function(){
    //循环执行,每隔1秒钟执行一次 1000 
    var t1=window.setInterval(refreshCount, 1000);
    function refreshCount() {
      console.log("ready");
    }
    //去掉定时器的方法  
    window.clearInterval(t1);   
 }); 
</script>

2.定时执行:当方法执行完成定时器停止(但是定时器还在,只不过没用了);

var tmid = window.setTimeout(“方法名或方法”, “延时”);

window.clearTimeout(tmid);

<script type="text/javascript">
  $(document).ready(function(){
    //定时执行,5秒后执行
    var t1=window.setTimeout(refreshCount, 1000 * 5);
    function refreshCount() {
      console.log("ready");
    }
    //去掉定时器的方法  
    window.clearTimeout(t1);   
 }); 
</script>

JS中的定时器是有返回值的:->返回值是一个数字,代表当前是第几个定时器

      var timer1=window.setTimeout(function(){},1000);  //timer1->1 当前是第一个定时器
       var timer2=window.setTimeout(function(){},1000); //timer2->2 当前是第二个定时器

      window.clearTimeout(timer1); //->把第一个定时器清除掉,这里也可以用
      window.clearInterval(timer1)、window.clearTimeout(1)、window.clearInterval(timer1);

  var timer3=window.setTimeout(function(){},1000);   //timer3->3 
  当前是第三个定时器 ,虽然上面的定时器timer1清除掉了,但是号还是继续往后排的;

 清除定时器:

window.clearInterval(timer1)/window.clearTimeout(time1);两种清除方式都可以清除

通过setTimeout和setInterval设置的定时器(两种方式在设置定时器的时候有区别,清除定时器的时候没有区别),参数不仅可以是timer,还可以是其返回值,例如1,2;

需要注意的是,定时器即使清除了,其返回值也不会清除,之后设置的定时器的返回值也会在其返回值的基础上继续向后排,这点类似于银行的排队领号,即使1号的业务办理完了,后边的人仍是从2号开始继续领号,而不是重新从1开始;

 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
HTML页面退出关闭定时器: 在HTML页面,当你离开或者关闭页面时,应该清除所有的定时器以释放内存,可以使用以下代码实现: ```javascript window.onbeforeunload = function(){ clearInterval(timer);//清除定时器 } ``` JavaScript设置定时器: JavaScript两种定时器:setInterval() 和 setTimeout()。setInterval() 方法会按照指定周期(以毫秒计)来调用函数,setTimeout() 方法会在指定的时间后执行一次。 setInterval() 语法: ```javascript var intervalID = window.setInterval(func, delay, [param1, param2, ...]); ``` setTimeout() 语法: ```javascript var timeoutID = window.setTimeout(func, delay, [param1, param2, ...]); ``` 取消定时器: 使用clearInterval() 或 clearTimeout() 方法可以取消定时器。 clearInterval() 语法: ```javascript window.clearInterval(intervalID); ``` clearTimeout() 语法: ```javascript window.clearTimeout(timeoutID); ``` 执行机制解析: setInterval() 和 setTimeout() 方法使用了 JavaScript 的事件循环机制。在 JavaScript ,事件循环会不断地从任务队列取出任务并执行,当任务队列为空时,事件循环会一直等待新的任务加入。 setInterval() 和 setTimeout() 方法会把回调函数推入任务队列,当时间到达后,事件循环会执行这个任务。setInterval() 方法会不断地将同一个任务推入任务队列,直到使用 clearInterval() 方法取消定时器。setTimeout() 方法只会推入一个任务,执行后就结束了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值