0

0

如何正确清除并重置 setInterval 定时器

碧海醫心

碧海醫心

发布时间:2025-12-25 19:33:07

|

704人浏览过

|

来源于php中文网

原创

如何正确清除并重置 setInterval 定时器

在拖拽操作中重复调用 `setinterval` 会导致多个定时器同时运行,造成计时混乱;解决方法是将定时器 id 提升至全局作用域,并在每次启动新定时器前调用 `clearinterval` 清除旧定时器。

在实现如“汉诺塔”这类带倒计时机制的交互游戏时,一个常见需求是:每当用户开始拖拽某个元素(如圆盘),倒计时就应重置为初始值(例如 10 秒),并重新开始计时。但若直接在 start 回调中反复调用 timer(),而未清理前一次的 setInterval,就会导致多个定时器并发执行——表现为倒计时跳变加快、多次弹出“Game over”警告,甚至页面异常刷新。

根本原因在于:setInterval 返回一个唯一的定时器 ID(数值),只有通过 clearInterval(id) 才能终止对应任务;而原代码中 downloadTimer 是函数内局部变量,每次调用 timer() 都会创建全新变量,旧定时器 ID 丢失,无法清除。

✅ 正确做法是:

  • 将定时器 ID 声明为模块级(或全局)变量,确保可被多次访问与清除;
  • 在 timer() 函数开头主动清除已有定时器,避免残留;
  • 启动新定时器后,将新 ID 赋值给该变量,维持最新引用。

以下是优化后的完整实现:

Play.ht
Play.ht

根据文本生成多种逼真的语音

下载
// ✅ 全局声明定时器 ID(推荐放在闭包或模块顶层)
let downloadTimer = null;

function timer() {
  // ? 每次启动前先清除可能存在的旧定时器
  if (downloadTimer !== null) {
    clearInterval(downloadTimer);
  }

  let timeleft = 10;
  downloadTimer = setInterval(() => {
    if (timeleft <= 0) {
      clearInterval(downloadTimer); // ✅ 清理自身,防内存泄漏
      alert("Game over! You ran out of time\nPlay again ?");
      location.reload();
    } else {
      timeleft -= 1;
      document.getElementById("timer").textContent = timeleft;
    }
  }, 1000);
}

function Drag() {
  $(".draggable").draggable({
    stack: $(".draggable"),
    helper: "clone",
    start: function () {
      timer(); // ✅ 每次拖拽开始即重置计时

      // 其余逻辑(如记录平台、序列等)保持不变
      const parentNode = "#" + this.parentNode.id;
      platforms.push(parentNode);
      const shape = "#" + this.id;
      sequence.push(shape);
      const shapeParent = "#" + this.closest(".holder").id;
    }
  });
}

⚠️ 注意事项:

  • 不要使用 var downloadTimer 在函数内重复声明,否则无法跨调用共享;
  • clearInterval(null) 或 clearInterval(undefined) 是安全的,不会报错,因此可省略判空(但显式判断更清晰);
  • 若应用需支持多实例(如多个独立计时区域),建议封装为类或工厂函数,避免全局污染;
  • 更现代的替代方案是使用 setTimeout 递归调用(更易控制、无 ID 管理负担),但 setInterval 在简单倒计时场景中仍简洁高效。

总结:定时器管理的核心原则是「一启一清」——每次新建前必清旧,每次结束时必清己。这不仅是解决重叠计时的关键,更是编写健壮前端定时逻辑的基本功。

相关专题

更多
c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

226

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

430

2024.03.01

undefined是什么
undefined是什么

undefined是代表一个值或变量不存在或未定义的状态。它可以作为默认值来判断一个变量是否已经被赋值,也可以用于设置默认参数值。尽管在不同的编程语言中,undefined可能具有不同的含义和用法,但理解undefined的概念可以帮助我们更好地理解和编写程序。本专题为大家提供undefined相关的各种文章、以及下载和课程。

3757

2023.07.31

网页undefined是什么意思
网页undefined是什么意思

网页undefined是指页面出现了未知错误的意思,提示undefined一般是在开发网站的时候定义不正确或是转换不正确,或是找不到定义才会提示undefined未定义这个错误。想了解更多的相关内容,可以阅读本专题下面的文章。

2872

2024.08.14

网页undefined啥意思
网页undefined啥意思

本专题整合了undefined相关内容,阅读下面的文章了解更多详细内容。后续继续更新。

4

2025.12.25

苹果官网入口直接访问
苹果官网入口直接访问

苹果官网直接访问入口是https://www.apple.com/cn/,该页面具备0.8秒首屏渲染、HTTP/3与Brotli加速、WebP+AVIF双格式图片、免登录浏览全参数等特性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

115

2025.12.24

拼豆图纸在线生成器
拼豆图纸在线生成器

拼豆图纸生成器有PixelBeads在线版、BeadGen和“豆图快转”;推荐通过pixelbeads.online或搜索“beadgen free online”直达官网,避开需注册的诱导页面。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

84

2025.12.24

俄罗斯搜索引擎yandex官方入口地址(最新版)
俄罗斯搜索引擎yandex官方入口地址(最新版)

Yandex官方入口网址是https://yandex.com。用户可通过网页端直连或移动端浏览器直接访问,无需登录即可使用搜索、图片、新闻、地图等全部基础功能,并支持多语种检索与静态资源精准筛选。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

553

2025.12.24

JavaScript ES6新特性
JavaScript ES6新特性

ES6是JavaScript的根本性升级,引入let/const实现块级作用域、箭头函数解决this绑定问题、解构赋值与模板字符串简化数据处理、对象简写与模块化提升代码可读性与组织性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

155

2025.12.24

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Node.js 教程
Node.js 教程

共57课时 | 7.3万人学习

CSS3 教程
CSS3 教程

共18课时 | 4万人学习

Vue 教程
Vue 教程

共42课时 | 5.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号