JavaScript 任务 - clearTimeout 函数与 clearInterval 函数

clearTimeout 函数

1、基本介绍
  • clearTimeout 函数用于取消先前通过 setTimeout 函数设置的定时器
clearTimeout(【timeoutID】)
参数说明
timeoutID要取消的定时器的标识符,这个 ID 是由 setTimeout 函数返回的
2、演示
let timeoutId1 = setTimeout(() => {console.log("这段代码不会执行");
}, 1000);let timeoutId2 = setTimeout(() => {console.log("这段代码会执行");
}, 1000);clearTimeout(timeoutId1);
# 输出结果这段代码会执行
3、注意事项
  1. 如果定时器已经触发,调用 clearTimeout 函数不会有任何效果
let timeoutId1 = setTimeout(() => {console.log("定时器 1 执行了");
}, 1000);let timeoutId2 = setTimeout(() => {console.log("取消定时器 1");clearTimeout(timeoutId1);
}, 2000);
# 输出结果定时器 1 执行了
取消定时器 1
  1. 如果定时器已经取消,调用 clearTimeout 函数不会有任何效果
let timeoutId1 = setTimeout(() => {console.log("这段代码不会执行");
}, 1000);let timeoutId2 = setTimeout(() => {console.log("这段代码会执行");
}, 1000);clearTimeout(timeoutId1);
clearTimeout(timeoutId1);
# 输出结果这段代码会执行
  1. 传入无效的 ID 不会报错,也不会有任何效果
clearTimeout(null);
clearTimeout(undefined);
clearTimeout("");
clearTimeout(0);
clearTimeout(123);
clearTimeout(NaN);
clearTimeout(false);
  1. setTimeout 函数与 setInterval 函数共享同一个 ID 池,在技术上可以混用 clearTimeout 函数和 clearInterval 函数,但是,为了清楚起见,应该避免这样做
let id = setInterval(() => {console.log("定时器执行了");
}, 1000);setTimeout(() => {console.log("取消定时器");clearTimeout(id);
}, 5000);
# 输出结果定时器执行了
定时器执行了
定时器执行了
定时器执行了
定时器执行了
取消定时器

clearInterval 函数

1、基本介绍
  • clearInterval 函数用于取消先前通过 setInterval 函数设置的定时器
clearInterval(【intervalID】)
参数说明
intervalID要取消的定时器的标识符,这个 ID 是由 setInterval 函数返回的
2、演示
let counter = 0;let intervalId = setInterval(() => {counter++;console.log(`计数: ${counter}`);if (counter >= 5) {clearInterval(intervalId);console.log("定时器已停止");}
}, 1000);
# 输出结果计数: 1
计数: 2
计数: 3
计数: 4
计数: 5
定时器已停止
3、注意事项
  1. 如果定时器已经取消,调用 clearInterval 函数不会有任何效果
let counter = 0;let intervalId = setInterval(() => {counter++;console.log(`计数: ${counter}`);
}, 1000);setTimeout(() => {console.log("取消定时器");clearInterval(intervalId);clearInterval(intervalId);
}, 5000);
# 输出结果计数: 1
计数: 2
计数: 3
计数: 4
计数: 5
取消定时器
  1. 传入无效的 ID 不会报错,也不会有任何效果
clearInterval(null);
clearInterval(undefined);
clearInterval("");
clearInterval(0);
clearInterval(123);
clearInterval(NaN);
clearInterval(false);
  1. setTimeout 函数与 setInterval 函数共享同一个 ID 池,在技术上可以混用 clearTimeout 函数和 clearInterval 函数,但是,为了清楚起见,应该避免这样做
let timeoutId1 = setTimeout(() => {console.log("这段代码不会执行");
}, 1000);let timeoutId2 = setTimeout(() => {console.log("这段代码会执行");
}, 1000);clearInterval(timeoutId1);
# 输出结果这段代码会执行

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/web/93298.shtml
繁体地址,请注明出处:http://hk.pswp.cn/web/93298.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

在 CentOS 7 中使用 systemd 创建自定义服务

systemd 创建自定义服务简述创建自定义服务步骤文件覆盖优先级创建服务流程在 /etc/systemd/system/ 目录下创建 .service 文件(需 root 权限):编写服务配置模板Systemd 服务文件三大区块详解[Unit] 区块 - 服务元数据与依赖[Service] 区块 -…

【QT】printsupport库远程实现打印机打印

【QT】printsupport库远程实现打印机打印 前言 思路 实现 当前所有可用打印机浏览 打印预览 打印输出 手动选择打印 自动打印 防呆补充 库打包 前言 在打印机的通讯控制方式中,有USB、网口、串口、WIFI等,针对局域网环境下,用自研软件控制打印机打印的应用场景,针对自研软…

LT3045EDD#TRPBF ADI亚德诺 超低噪声LDO稳压器 电子元器件IC

LT3045EDD#TRPBF ADI 超低噪声LDO稳压器专业解析1. 产品技术档案LT3045EDD#TRPBF是ADI(Analog Devices Inc.)推出的超低噪声/超高PSRR线性稳压器,采用DFN-12 (3x3mm)封装,以其0.8μVRMS超低噪声和79dB超高频PSRR成为精密电源设计。…

易语言模拟真人鼠标轨迹算法 - 非贝塞尔曲线

一.简介 鼠标轨迹算法是一种模拟人类鼠标操作的程序,它能够模拟出自然而真实的鼠标移动路径。 鼠标轨迹算法的底层实现采用C/C语言,原因在于C/C提供了高性能的执行能力和直接访问操作系统底层资源的能力。 鼠标轨迹算法具有以下优势: 模拟人…

Spring Boot 3 数据源连接信息存储方法

在Spring Boot 3中,数据源连接信息的存储方式主要有以下几种,根据安全性和环境需求选择合适的方式: 1. 配置文件(推荐基础方式) 位置:src/main/resources/application.properties 或 application.yml 示例…

按键序列常用示例

按键序列常用示例 按键编码 基础按键对应编码 A-Z 原字符即可 KeyCodeSHIFTCTRL^ALT% 其他按键 KeyCodeBACKSPACE{BACKSPACE}, {BS}, or {BKSP}BREAK{BREAK}CAPS LOCK{CAPSLOCK}DEL or DELETE{DELETE} or {DEL}DOWN ARROW{DOWN}END{END}ENTER{ENTER} or ~ESC{ESC}HELP{HEL…

【LeetCode Solutions】LeetCode 热题 100 题解(36 ~ 40)

CONTENTS二叉树 - LeetCode 94. 二叉树的中序遍历(简单)二叉树 - LeetCode 104. 二叉树的最大深度(简单)二叉树 - LeetCode 226. 翻转二叉树(简单)二叉树 - LeetCode 101. 对称二叉树(简单&…

数据处理分析环境搭建+Numpy使用教程

环境搭建 数据分析常用开源库 Numpy NumPy(Numerical Python) 是 Python 语言的一个扩展程序库。是一个运行速度非常快的数学库,主要用于数组计算包含: 一个强大的N维数组对象 ndarray广播功能函数整合 C/C/Fortran 代码的工具线性代数、傅里叶变换、随机…

实战多屏Wallpaper壁纸显示及出现黑屏问题bug分析-学员作业

背景: 在大家看了上一篇google官方对于多屏壁纸这块的介绍后 安卓Wallpaper壁纸部分对多屏的支持-Google官方文档介绍 可能还是对于壁纸支持多屏这块没有相关的实战性的认知,所以本文就开始带大家来进行部分解读和实战。 壁纸多屏显示原理文档解读&a…

Vue插槽---slot详解

1、什么是 Vue 插槽?Vue 插槽(Slot)​​ 是 Vue 提供的一种非常强大且灵活的机制,用于实现:父组件向子组件传递一段模板内容(HTML / 组件等),让子组件在指定位置动态渲染这些内容。可…

STM32 - Embedded IDE - GCC - 显著减少固件的体积

导言如上图所示,在编译器附加选项(全局)里添加--specsnano.specs,告诉编译器使用newlib-nano替代newlib去编译代码。 newlib vs. newlib-nano newlib 是 GNU ARM 工具链默认的 C 标准库,功能完整,但体积较大…

python的美食交流社区系统

前端开发框架:vue.js 数据库 mysql 版本不限 后端语言框架支持: 1 java(SSM/springboot)-idea/eclipse 2.NodejsVue.js -vscode 3.python(flask/django)–pycharm/vscode 4.php(thinkphp/laravel)-hbuilderx 数据库工具:Navicat/SQLyog等都可以 摘要&…

《Redis持久化机制对比与RDB/AOF调优方案》

📚 Redis持久化机制对比与RDB/AOF调优方案 🧠前言 在生产环境中,Redis 常常被用作缓存,但在更多场景下,它还存储着核心业务数据(如会话、订单、队列任务等)。一旦 Redis 宕机、数据丢失&#…

eXtremeDB 医疗设备开发实战:从合规到实时,构建 EN62304 级数据管理系统

在医疗设备开发领域,数据管理的 “可靠性” 与 “合规性” 是不可逾越的红线 —— 监护仪心率数据的丢失可能延误诊断时机,胰岛素泵剂量记录的错误则直接威胁患者生命安全。eXtremeDB 凭借对 EN62304 标准的深度合规支持、硬实时数据处理能力及多层次安全…

linux 设备驱动的分层思想

一、 概述像这样的分层设计在linux的input、RTC、MTD、I2c、SPI、tty、USB等诸多类型设备驱动中屡见不鲜,下面对这些驱动进行详细的分析。二、 输入设备驱动输入设备(如按键、键盘、触摸屏、鼠标等)是典型的字符设备,其一般的工…

【嵌入式硬件实例】-555定时器驱动直流无刷电机

555定时器驱动直流无刷电机 文章目录 555定时器驱动直流无刷电机 1、555定时器介绍 2、BLDC,无刷直流电机 3、DRV10866 驱动器 4、硬件准备与接线 5、电路工作原理 在这个项目中,我们将使用 555 定时器 IC 和 DRV10866 驱动器 IC 制作 BLDC、无刷直流电机驱动电路。无刷电机可…

Helm 常用命令 + Bitnami 中间件部署速查表

文章目录一、Helm 常用命令速查表1.1. 仓库管理1.2. Chart 搜索1.3. 应用部署1.4. 应用管理二、Bitnami 常用中间件部署示例三、常用自定义参数(values.yaml 配置项)四、安装后的访问方式五、一键安装脚本 install-middleware.sh5.1. 完整脚本5.2. 使用方…

Ansible 自动化运维实战系列(六):Valut详解

Ansible 自动化运维实战系列(六):Valut详解📚 系列导航一:概述二:命令1)创建加密文件2)加密已有文件3)查看加密文件4)编辑加密文件5)解密文件6&am…

《探秘浏览器Web Bluetooth API设备发现流程》

网页若需与蓝牙设备通信,往往需依赖本地客户端或专用驱动程序作为中介,不仅增加了用户操作成本,也限制了Web应用在跨设备场景中的拓展。而Web Bluetooth API的出现,直接赋予了网页与低功耗蓝牙(BLE)设备对话的能力,从智能手环的健康数据同步,到智能家居设备的远程控制,…

Jenkins+Python自动化持续集成详细教程

Python接口自动化测试零基础入门到精通(2025最新版)Jenkins安装 ​ Jenkins是一个开源的软件项目,是基于java开发的一种持续集成工具,用于监控持续重复的工作,旨在提供一个开放易用的软件平台,使软件的持续…