JavaScript 调度:setTimeout 和 setInterval

一、基础语法与核心差异

1. setTimeout:单次延迟执行

javascript 复制代码
const timerId = setTimeout(callback, delay, arg1, arg2, ...);  

功能 :在指定延迟(毫秒)后执行一次回调函数。

取消方法clearTimeout(timerId)

2. setInterval:循环重复执行

javascript 复制代码
const intervalId = setInterval(callback, interval, arg1, arg2, ...);  

功能 :每隔固定时间重复执行回调函数。

取消方法clearInterval(intervalId)

核心差异

setTimeout单次触发 ,适合延迟任务或递归实现循环。

setInterval固定间隔触发,适合周期性任务(需注意累积问题)。


二、实战技巧与经典问题

1. 用setTimeout模拟setInterval

由于setInterval可能因回调执行时间过长导致任务堆积 ,更安全的做法是递归调用setTimeout

javascript 复制代码
function safeInterval(callback, interval) {  
  let timerId = null;  
  function execute() {  
    callback();  
    timerId = setTimeout(execute, interval); // 递归调用  
  }  
  timerId = setTimeout(execute, interval);  
  return () => clearTimeout(timerId); // 返回清除函数  
}  

此方法确保每次回调执行完毕后再重新计时,避免任务重叠。

2. 事件循环与时间精度问题

JavaScript是单线程的,定时器的回调会被推入任务队列,实际执行时间可能晚于预期

javascript 复制代码
console.log("Start");  
setTimeout(() => console.log("Timeout"), 0);  
console.log("End");  
// 输出顺序:Start → End → Timeout  

即使延迟设为0,回调仍需等待主线程空闲。

3. 内存泄漏:忘记清除定时器

未及时调用clearTimeoutclearInterval会导致回调持续引用外部变量,内存无法释放

javascript 复制代码
function startPolling() {  
  setInterval(() => {  
    fetchData(); // 持续运行,即使组件已销毁  
  }, 5000);  
}  

解决方案:在组件卸载或条件变更时主动清除定时器。


三、高级应用场景

1. 节流(Throttling)与防抖(Debouncing)

防抖:连续事件中只执行最后一次:

javascript 复制代码
function debounce(func, delay) {  
  let timerId;  
  return (...args) => {  
    clearTimeout(timerId);  
    timerId = setTimeout(() => func(...args), delay);  
  };  
}  

节流:固定时间内只执行一次:

javascript 复制代码
function throttle(func, interval) {  
  let lastTime = 0;  
  return (...args) => {  
    const now = Date.now();  
    if (now - lastTime >= interval) {  
      func(...args);  
      lastTime = now;  
    }  
  };  
}  
相关推荐
cg50172 分钟前
Spring Boot 中的自动配置原理
java·前端·数据库
尘寰ya2 分钟前
前端面试-React篇
前端·react.js·面试
vvilkim2 分钟前
React 高级特性与最佳实践
前端·javascript·react.js
拉不动的猪3 分钟前
vue与react中监听的简单对比
前端·javascript·面试
涵信4 分钟前
第七节:React HooksReact 18+新特性-并发模式(Concurrent Mode)解决了什么问题?
前端·javascript·react.js
冴羽10 分钟前
SvelteKit 最新中文文档教程(21)—— 最佳实践之图片
前端·javascript·svelte
纪元A梦20 分钟前
华为OD机试真题——跳格子3(2025A卷:200分)Java/python/JavaScript/C++/C语言/GO六种最佳实现
java·javascript·c++·python·华为od·go·华为od机试题
BillKu40 分钟前
遵守 Vue3 的单向数据流原则:父组件传递对象 + 子组件修改对象属性,安全地实现父子组件之间复杂对象的双向绑定示例代码及讲解
javascript·vue.js·elementui
李鸿耀1 小时前
Flex布局完全指南,Flexbox 在线演示工具推送
前端·flexbox
涵信1 小时前
第八节:React HooksReact 18+新特性-React Server Components (RSC) 工作原理
前端·react.js·前端框架