vue+moment将分钟调整为5的倍数(向下取整)
vue+moment将分钟调整为5的倍数(向下取整)
将时间调整为5的倍数的需求,可以通过计算分钟数并取整到最近的5的倍数来实现。以下是修改后的代码:
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的倍数(向下取整)// 处理开始时间stmconst 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');// 处理结束时间etmconst 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
,但根据注释描述,当前代码采用向下取整更符合需求。