vue+moment将分钟调整为5的倍数(向下取整)

vue+moment将分钟调整为5的倍数(向下取整)

将时间调整为5的倍数的需求,可以通过计算分钟数并取整到最近的5的倍数来实现。以下是修改后的代码:

javascript 复制代码
getSkSqRList() {
  let stm = '';
  let etm = '';

    stm = moment().subtract(6, 'hours').format('YYYY-MM-DD HH:mm');
    etm = moment().format('YYYY-MM-DD HH:mm');

  // 处理时刻类型:将分钟调整为5的倍数(向下取整)
    // 处理开始时间stm
    const stmMoment = moment(stm);
    const stmMinutes = stmMoment.minute(); // 获取当前分钟数
    const adjustedStmMinutes = Math.floor(stmMinutes / 5) * 5; // 计算5的倍数(向下取整)
    stmMoment.minute(adjustedStmMinutes);
    stm = stmMoment.format('YYYY-MM-DD HH:mm');
    
    // 处理结束时间etm
    const etmMoment = moment(etm);
    const etmMinutes = etmMoment.minute();
    const adjustedEtmMinutes = Math.floor(etmMinutes / 5) * 5;
    etmMoment.minute(adjustedEtmMinutes);
    etm = etmMoment.format('YYYY-MM-DD HH:mm');

  
  // 后续可以使用stm和etm进行请求等操作
  // ...
}

代码说明:

. 新增时刻处理逻辑

  • 通过minute()方法获取当前分钟数
  • 计算调整后的分钟数:Math.floor(分钟数 / 5) * 5(例如31分钟 → 30分钟,17分钟 → 15分钟)
  • 用调整后的分钟数更新时间,并重新格式化为字符串
    向下取整规则:严格按照注释要求,如17:31调整为17:30,17:34调整为17:30,17:35保持17:35

如果需要向上取整(例如17:31 → 17:35),可以将Math.floor改为Math.ceil,但根据注释描述,当前代码采用向下取整更符合需求。

相关推荐
Crystal32813 分钟前
App端用户每日弹出签到弹窗如何实现?(uniapp+Vue)
前端·vue.js
摸着石头过河的石头14 分钟前
Service Worker 深度解析:让你的 Web 应用离线也能飞
前端·javascript·性能优化
molly cheung20 分钟前
Vue3:watch与watchEffect的异同
vue.js·watch·store·watcheffect
不爱吃糖的程序媛1 小时前
Electron 如何判断运行平台是鸿蒙系统(OpenHarmony)
javascript·electron·harmonyos
Hilaku1 小时前
我用AI重构了一段500行的屎山代码,这是我的Prompt和思考过程
前端·javascript·架构
Cxiaomu1 小时前
React Native App 自动检测版本更新完整实现指南
javascript·react native·react.js
掘金安东尼2 小时前
前端周刊第439期(2025年11月3日–11月9日)
前端·javascript·vue.js
有蝉2 小时前
vue-office——支持多种文件(docx、excel、pdf)预览的vue组件库,支持vue2/3。也支持非Vue框架的预览。
vue.js·pdf·excel
起这个名字3 小时前
微前端应用通信使用和原理
前端·javascript·vue.js
QuantumLeap丶3 小时前
《uni-app跨平台开发完全指南》- 06 - 页面路由与导航
前端·vue.js·uni-app