0

0

如何实现鼠标移动或按键时重置倒计时器

霞舞

霞舞

发布时间:2026-02-02 13:04:18

|

764人浏览过

|

来源于php中文网

原创

如何实现鼠标移动或按键时重置倒计时器

本文讲解如何正确实现一个可被 `mousemove` 或 `keypress` 事件重置的 javascript 倒计时器,解决因作用域问题导致的重复弹窗和定时器失控问题。

在开发用户会话超时提醒功能时,常需实现“用户活跃即重置倒计时”的交互逻辑。但若直接将 setInterval 返回的定时器 ID(如变量 x)定义在 countdown() 函数内部,外部 resetTimer() 就无法访问该变量——这会导致 clearInterval(x) 失效、旧定时器持续运行,新定时器又被重复创建,最终引发多次 alert('times up') 弹窗等严重副作用。

✅ 正确做法是:将定时器引用提升为全局(或模块级)变量,确保 resetTimer() 和 countdown() 共享同一引用。以下是优化后的完整实现:



  
// ✅ 全局声明定时器引用,供 resetTimer 和 countdown 共享
let timer = null;

jQuery(document).ready(function () {
  // 绑定重置事件:鼠标移动或按键均触发
  $(document).on('mousemove keypress', resetTimer);
});

function resetTimer() {
  if (timer) {
    clearInterval(timer); // 清除当前运行中的定时器
  }
  countdown(); // 启动全新倒计时
}

function countdown() {
  // 设定倒计时终点:当前时间 + 10 分钟(10 * 60 * 1000 ms)
  const countDownDate = Date.now() + 10 * 60 * 1000;

  // ✅ 将 setInterval 返回值赋给全局 timer 变量
  timer = setInterval(() => {
    const now = Date.now();
    const distance = countDownDate - now;

    if (distance <= 0) {
      clearInterval(timer);
      document.getElementById("SessionCookieExpirationCountdown").innerHTML = "Countdown End";
      timeup();
      return;
    }

    // 计算剩余分钟与秒数(仅显示 mm:ss,忽略天/小时)
    const minutes = Math.floor((distance % (1000 * 60 * 60)) / (1000 * 60));
    const seconds = Math.floor((distance % (1000 * 60)) / 1000);

    document.getElementById("SessionCookieExpirationCountdown").innerHTML = 
      `Logging out in ${minutes}:${seconds < 10 ? '0' : ''}${seconds}`;
  }, 1000);
}

function timeup() {
  alert('Time\'s up! You have been logged out.');
}

? 关键改进说明:

ContentBot
ContentBot

内容自动化AI写作工具

下载
  • 使用 let timer = null 提升作用域,避免闭包隔离导致的引用丢失;
  • 采用 $(document).on('mousemove keypress', ...) 单次绑定多事件,更简洁高效;
  • resetTimer() 中增加 if (timer) 判断,防止首次调用时对 null 执行 clearInterval(虽无害但更健壮);
  • 倒计时显示补零(seconds
  • timeup() 中的 alert 仅触发一次,彻底杜绝重复弹窗。

⚠️ 注意事项:

  • 避免在 countdown() 内重复声明 var x = setInterval(...) —— 这是原始 Bug 根源;
  • 若页面含 iframe 或需监听特定区域,应将事件委托至对应容器而非 document;
  • 生产环境建议用 confirm() 或模态框替代 alert(),并集成自动登出逻辑(如清除 Cookie、跳转登录页);
  • 考虑添加防抖(debounce)机制,防止高频 mousemove 过度触发重置(本例中影响较小,可按需增强)。

通过以上重构,倒计时器即可稳定响应用户交互,精准重置,并为会话管理提供可靠的时间控制基础。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

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

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

238

2023.09.22

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

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

499

2024.03.01

if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

786

2023.08.22

cookie
cookie

Cookie 是一种在用户计算机上存储小型文本文件的技术,用于在用户与网站进行交互时收集和存储有关用户的信息。当用户访问一个网站时,网站会将一个包含特定信息的 Cookie 文件发送到用户的浏览器,浏览器会将该 Cookie 存储在用户的计算机上。之后,当用户再次访问该网站时,浏览器会向服务器发送 Cookie,服务器可以根据 Cookie 中的信息来识别用户、跟踪用户行为等。

6433

2023.06.30

document.cookie获取不到怎么解决
document.cookie获取不到怎么解决

document.cookie获取不到的解决办法:1、浏览器的隐私设置;2、Same-origin policy;3、HTTPOnly Cookie;4、JavaScript代码错误;5、Cookie不存在或过期等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

349

2023.11.23

阻止所有cookie什么意思
阻止所有cookie什么意思

阻止所有cookie意味着在浏览器中禁止接受和存储网站发送的cookie。阻止所有cookie可能会影响许多网站的使用体验,因为许多网站使用cookie来提供个性化服务、存储用户信息或跟踪用户行为。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

415

2024.02.23

cookie与session的区别
cookie与session的区别

本专题整合了cookie与session的区别和使用方法等相关内容,阅读专题下面的文章了解更详细的内容。

95

2025.08.19

go语言闭包相关教程大全
go语言闭包相关教程大全

本专题整合了go语言闭包相关数据,阅读专题下面的文章了解更多相关内容。

137

2025.07.29

AO3官网入口与中文阅读设置 AO3网页版使用与访问
AO3官网入口与中文阅读设置 AO3网页版使用与访问

本专题围绕 Archive of Our Own(AO3)官网入口展开,系统整理 AO3 最新可用官网地址、网页版访问方式、正确打开链接的方法,并详细讲解 AO3 中文界面设置、阅读语言切换及基础使用流程,帮助用户稳定访问 AO3 官网,高效完成中文阅读与作品浏览。

16

2026.02.02

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 4.5万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 2.6万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.1万人学习

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

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