前端实现定时任务,每天定时更新数据 “ setInterval + new Date()(或moment.js)“

项目场景:

每天定时更新系统数据,前端通过系统时间及setInterval来实现


问题描述

在项目中会遇到一些情况,比如用户不关闭设备,导致设备有时无法同步最新的数据,这里就需要通过特定时间来重新获取最新数据并渲染出来,此时就需要通过定时任务来满足这种需求;


解决方案:

提示:这里通过new Date()计算时间差,通过定时器setInterval来实现指定时间更新数据:

javascript 复制代码
// 切记,登录系统后先跑一下定时任务
timedTask();


/* 定时任务,每天定时获取数据 */
export const timedTask = () => {
  // 获取当前时间
  const now: any = new Date();

  // 这里设置刷新时间为每天固定时间(例如 08:00:00)
  const refreshTime: any = new Date(now.getFullYear(), now.getMonth(), now.getDate(), 8, 0, 0);

  // 计算当前时间距离刷新时间的时间间隔(以毫秒为单位)
  const timeUntilRefresh: any = refreshTime - now;

  // 如果当前时间已经超过刷新时间,则将刷新时间设置为明天的同一时间
  if (timeUntilRefresh < 0) {
    refreshTime.setDate(refreshTime.getDate() + 1);
  }

  // console.log(refreshTime - Date.now(), '定时任务,每天定时获取数据');

  // 设置定时任务,每天固定时间执行刷新数据函数
  const timer = setInterval(() => {
    if ("TODO:需求特定条件") {
    // 时间到处理你的方法
      yourFunction();
       //这里记得清除一下定时器,后面说明原因
      clearInterval(timer);
    }
  }, refreshTime - Date.now());
};




/* 需要处理数据的方法 */
export const yourFunction = () => {
  setTimeout(() => {
    timedTask();
  }, 180000); // 暂定,三分钟后重新开启定时任务
  // ......
  // ......
  // ......
  // 这里处理数据
}

提示:
new Date(year, month, day, hours, minutes, seconds, milliseconds) // 注意:这种方式下,必须传递整型;

各种变量代表的含义是:

month: 用英文 表示月份名称,从January到December ,缩写也行(Jan...Dec);

year: 四位数表示的年份

month: 用整数表示月份,从0(1月)到11(12月)

day: 表示一个月中的第几天,从1到31, defaults to 1.

hours: 小时数,从0(午夜)到23(晚11点), defaults to 0.

minutes: 分钟数,从0到59的整数, defaults to 0.

seconds: 秒数,从0到59的整数, defaults to 0.

milliseconds: 毫秒数,为大于等于0的整数, defaults to 0.

这里也可以使用使用moment插件将日期转换为毫秒数非常简单。可以使用moment().valueOf()方法来获取当前时间的毫秒数,也可以使用moment(日期).valueOf()方法将给定日期转换为毫秒数。

// 假设你有一个不同格式的时间字符串

const timeString = "15-11-2023 16:30:35";

// 使用 moment 解析这个格式的时间字符串,指定格式

const time = moment(timeString, "DD-MM-YYYY HH:mm:ss");

// 然后使用 valueOf 获取这个时间的 Unix 时间戳(毫秒数)

const timestamp = time.valueOf();

console.log(timestamp); // 输出时间的毫秒表示

相关链接:
JavaScript简单倒计时效果的实现

相关推荐
咬_咬11 小时前
go语言学习(数组与切片)
开发语言·学习·golang·数组·切片
兔子零102411 小时前
Claude Code 都把宠物养进终端了,我做了一个真正能长期玩的中文宠物游戏
前端·游戏·游戏开发
xiaotao13111 小时前
Vite 与 Webpack 开发/打包时环境变量对比
前端·vue.js·webpack
小陈工11 小时前
Python Web开发入门(十八):跨域问题解决方案——从“为什么我的请求被拦了“到“我让浏览器乖乖听话“
开发语言·python·机器学习·架构·数据挖掘·回归·状态模式
m0_4972141511 小时前
Qt事件系统
开发语言·qt
AI科技星11 小时前
全维度相对论推导、光速螺旋时空与北斗 GEO 钟差的统一理论
开发语言·线性代数·算法·机器学习·数学建模
摆烂工程师11 小时前
教你如何查询 Codex 最新额度是多少,以及 ChatGPT Pro、Plus、Business 最新额度变化
前端·后端·ai编程
赵优秀一一11 小时前
Python 工程化基础1:环境(conda)、pip、requirements.txt
linux·开发语言·python
捧月华如11 小时前
响应式设计原理与实践:适配多端设备的前端秘籍
前端·前端框架·json
笨笨狗吞噬者11 小时前
VSCode 插件推荐 Copy Filename Pro,快速复制文件、目录和路径的首选
前端·visual studio code