用setTimeout代替setInterval

前言

今天分享的小技巧是我在工作开发过程中遇到的一个问题,觉得处理这个问题比较不错,给大家分享一下

一、场景

当时的场景大致是这个样子的,拿到一个带开始时间和结束时间的一个对象数组,当当前时间在对象某一个时间段的时候,需要查询这个时间段的数据,当然查询数据在这不做考虑

javascript 复制代码
const arr = [
  { startTime: '2026-01-08 20:15', endTime: '2026-01-08 20:31', id: 1 },
  {
    startTime: '2026-01-08 20:32',
    endTime: '2026-01-08 20:45',
    id: 2,
  },
]

当当前时间在20:15-20:31的时候,需要干其他事,当在20:32-20:45需要做一些事

这就是这个问题的场景

二、方案

我相信大家有一个方案肯定轮询,去不断反复判断当前时间在哪个阶段;

但是这种会有以下几个问题

  1. 如果轮询设置时间过长,会导致无法及时获取数据;比如我设置10分钟一次,但是恰好我一分钟的时候就进入20:32,那么我需要额外等待9分钟才能查到数据
  2. 如果设置过短,计算太过频繁,会影响性能(当然性能影响很小)

这就引出我们今天这个解决方案,用setTimeout来处理

解决方案

大致思路事,初始化调用的时候计算当前时间与下一条的开始时间的差值,然后在setTimeout里面继续执行这个方法,延迟时长设置为你计算的差值,代码如下

javascript 复制代码
import dayjs from 'dayjs'
const arr = [
  { startTime: '2026-01-08 20:15', endTime: '2026-01-08 20:46', id: 1 },
  {
    startTime: '2026-01-08 20:47',
    endTime: '2026-01-08 20:45',
    id: 2,
  },
]
// 获取当前时间戳
export const getCurrentTime = () => {
  return dayjs().unix()
}
// 比较当前时间
export const culcTime = (time: string) => {
  const currentTime = getCurrentTime()
  //   获取20:15的时间戳
  const timeStamp = dayjs(time).unix()
  return timeStamp - currentTime
}
// 干其他事
const doOtherThing = () => {
  console.log('干一些其他事')
}
export const checkTime = () => {
  const time = culcTime(arr[1].startTime)
  doOtherThing()
  
  if (time <= 0) {
    return
  }
  setTimeout(() => {
    checkTime()
  }, time * 1000)
}

我们看一下案例,数据的开始结束时间,自己定义以下

第一次

第二次

这样就能很好的避免上面所说的一些问题

虽然setTimeout也并不非常准确(dddd(懂得都懂)),但是这些误差是在能接受的范围的

也并不需要考虑

总结

以上就是一种在这种场景的比较好的优化手段,ai给的提示(ai真猛)

如果有更好的方案,欢迎提出

相关推荐
@大迁世界4 分钟前
1.什么是 ReactJS?
前端·javascript·react.js·前端框架·ecmascript
阿贵---22 分钟前
C++中的RAII技术深入
开发语言·c++·算法
Traced back28 分钟前
怎么用 Modbus 让两个设备互相通信**,包含硬件接线、协议原理、读写步骤,以及 C# 实操示例。
开发语言·c#
BJ-Giser1 小时前
Cesium 基于EZ-Tree的植被效果
前端·可视化·cesium
王码码20352 小时前
Flutter for OpenHarmony:Flutter 三方库 algoliasearch 毫秒级云端搜索体验(云原生搜索引擎)
android·前端·git·flutter·搜索引擎·云原生·harmonyos
发现一只大呆瓜2 小时前
深入浅出 AST:解密 Vite、Babel编译的底层“黑盒”
前端·面试·vite
娇娇yyyyyy2 小时前
QT编程(17): Qt 实现自定义列表模型
开发语言·qt
天天鸭2 小时前
前端仔写了个 AI Agent,才发现大模型只干了 10% 的活
前端·python·ai编程
ms_27_data_develop2 小时前
Java枚举类、异常、常用类
java·开发语言