iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >JavaScript自动生成24小时时间区间
  • 466
分享到

JavaScript自动生成24小时时间区间

2024-04-02 19:04:59 466人浏览 安东尼
摘要

目录1、时间跨度为60分钟(1)时间区间为字符串(2)时间区间为数组(3)时间区间为对象2、时间跨度为30分钟(1)时间区间为字符串(2)时间区间为数组(3)时间区间为对象3、时间跨

1、时间跨度为60分钟

(1)时间区间为字符串

有时候可能需要用到24小时的时间区间,跨度为60分钟,比如下面这样的:

['00:00 - 01:00', '01:00 - 02:00', '02:00 - 03:00', '03:00 - 04:00', '04:00 - 05:00', '05:00 - 06:00', '06:00 - 07:00', '07:00 - 08:00', '08:00 - 09:00', '09:00 - 10:00', '10:00 - 11:00', '11:00 - 12:00', '12:00 - 13:00', '13:00 - 14:00', '14:00 - 15:00', '15:00 - 16:00', '16:00 - 17:00', '17:00 - 18:00', '18:00 - 19:00', '19:00 - 20:00', '20:00 - 21:00', '21:00 - 22:00', '22:00 - 23:00', '23:00 - 24:00']

如果手动去写,则有点麻烦,这个时候可以使用一个简单的 JS 函数去自动生成,示例代码如下:

function generateTimes() {
    let timeArrays = new Array(24).fill("");

    timeArrays.forEach((item, index) => timeArrays[index] = (index < 10 ? '0' + index : index) + ':00' + ' - ' + ((index + 1) < 10 ? '0' + (index + 1) : (index + 1)) + ':00');

    return timeArrays;
}

当然,上面的方法,也可以简写成下面这样的,只需要一行代码即可

let timeArrays = new Array(24).fill('').map((item, index) => (index < 10 ? '0' + index : index) + ':00' + ' - ' + ((index + 1) < 10 ? '0' + (index + 1) : (index + 1)) + ':00');

(2)时间区间为数组

let timeArrays = new Array(24).fill(['', '']).map((item, index) => [(index < 10 ? '0' + index : index) + ':00', ((index + 1) < 10 ? '0' + (index + 1) : (index + 1)) + ':00']);
console.log(JSON.stringify(timeArrays));

生成的时间区间如下:

[["00:00","01:00"],["01:00","02:00"],["02:00","03:00"],["03:00","04:00"],["04:00","05:00"],["05:00","06:00"],["06:00","07:00"],["07:00","08:00"],["08:00","09:00"],["09:00","10:00"],["10:00","11:00"],["11:00","12:00"],["12:00","13:00"],["13:00","14:00"],["14:00","15:00"],["15:00","16:00"],["16:00","17:00"],["17:00","18:00"],["18:00","19:00"],["19:00","20:00"],["20:00","21:00"],["21:00","22:00"],["22:00","23:00"],["23:00","24:00"]]

(3)时间区间为对象

let timeArrays = new Array(24).fill({}).map((item, index) => {
    return {
        start: (index < 10 ? '0' + index : index) + ':00',
        end: ((index + 1) < 10 ? '0' + (index + 1) : (index + 1)) + ':00'
    }
});
console.log(jsON.stringify(timeArrays));

生成的时间区间如下:

[{"start":"00:00","end":"01:00"},{"start":"01:00","end":"02:00"},{"start":"02:00","end":"03:00"},{"start":"03:00","end":"04:00"},{"start":"04:00","end":"05:00"},{"start":"05:00","end":"06:00"},{"start":"06:00","end":"07:00"},{"start":"07:00","end":"08:00"},{"start":"08:00","end":"09:00"},{"start":"09:00","end":"10:00"},{"start":"10:00","end":"11:00"},{"start":"11:00","end":"12:00"},{"start":"12:00","end":"13:00"},{"start":"13:00","end":"14:00"},{"start":"14:00","end":"15:00"},{"start":"15:00","end":"16:00"},{"start":"16:00","end":"17:00"},{"start":"17:00","end":"18:00"},{"start":"18:00","end":"19:00"},{"start":"19:00","end":"20:00"},{"start":"20:00","end":"21:00"},{"start":"21:00","end":"22:00"},{"start":"22:00","end":"23:00"},{"start":"23:00","end":"24:00"}]

2、时间跨度为30分钟

如果时间跨度为30分钟,也就是说1天24小时,需要分成48个时间区间。

(1)时间区间为字符串

let timeArrays = new Array(48).fill('').map((item, index) => {
    let startVal = index * 30;
    let endVal = (index + 1) * 30;
    let startHour = Math.floor((startVal / 60));
    let startMinute = (startVal % 60);
    let endHour = Math.floor((endVal / 60));
    let endMinute = (endVal % 60);
    let startTime = ((startHour < 10) ? ('0' + startHour) : startHour) + ':' + (startMinute === 0 ? '00' : startMinute);
    let endTime = ((endHour < 10) ? ('0' + endHour) : endHour) + ':' + (endMinute === 0 ? '00' : endMinute);
    
    return startTime + ' - ' + endTime;
});
console.log(timeArrays);

生成的时间区间如下:

['00:00 - 00:30', '00:30 - 01:00', '01:00 - 01:30', '01:30 - 02:00', '02:00 - 02:30', '02:30 - 03:00', '03:00 - 03:30', '03:30 - 04:00', '04:00 - 04:30', '04:30 - 05:00', '05:00 - 05:30', '05:30 - 06:00', '06:00 - 06:30', '06:30 - 07:00', '07:00 - 07:30', '07:30 - 08:00', '08:00 - 08:30', '08:30 - 09:00', '09:00 - 09:30', '09:30 - 10:00', '10:00 - 10:30', '10:30 - 11:00', '11:00 - 11:30', '11:30 - 12:00', '12:00 - 12:30', '12:30 - 13:00', '13:00 - 13:30', '13:30 - 14:00', '14:00 - 14:30', '14:30 - 15:00', '15:00 - 15:30', '15:30 - 16:00', '16:00 - 16:30', '16:30 - 17:00', '17:00 - 17:30', '17:30 - 18:00', '18:00 - 18:30', '18:30 - 19:00', '19:00 - 19:30', '19:30 - 20:00', '20:00 - 20:30', '20:30 - 21:00', '21:00 - 21:30', '21:30 - 22:00', '22:00 - 22:30', '22:30 - 23:00', '23:00 - 23:30', '23:30 - 24:00']

(2)时间区间为数组

let timeArrays = new Array(48).fill(['', '']).map((item, index) => {
    let startVal = index * 30;
    let endVal = (index + 1) * 30;
    let startHour = Math.floor((startVal / 60));
    let startMinute = (startVal % 60);
    let endHour = Math.floor((endVal / 60));
    let endMinute = (endVal % 60);
    let startTime = ((startHour < 10) ? ('0' + startHour) : startHour) + ':' + (startMinute === 0 ? '00' : startMinute);
    let endTime = ((endHour < 10) ? ('0' + endHour) : endHour) + ':' + (endMinute === 0 ? '00' : endMinute);
    
    return [startTime, endTime];
});
console.log(JSON.stringify(timeArrays));

生成的时间区间如下:

[["00:00","00:30"],["00:30","01:00"],["01:00","01:30"],["01:30","02:00"],["02:00","02:30"],["02:30","03:00"],["03:00","03:30"],["03:30","04:00"],["04:00","04:30"],["04:30","05:00"],["05:00","05:30"],["05:30","06:00"],["06:00","06:30"],["06:30","07:00"],["07:00","07:30"],["07:30","08:00"],["08:00","08:30"],["08:30","09:00"],["09:00","09:30"],["09:30","10:00"],["10:00","10:30"],["10:30","11:00"],["11:00","11:30"],["11:30","12:00"],["12:00","12:30"],["12:30","13:00"],["13:00","13:30"],["13:30","14:00"],["14:00","14:30"],["14:30","15:00"],["15:00","15:30"],["15:30","16:00"],["16:00","16:30"],["16:30","17:00"],["17:00","17:30"],["17:30","18:00"],["18:00","18:30"],["18:30","19:00"],["19:00","19:30"],["19:30","20:00"],["20:00","20:30"],["20:30","21:00"],["21:00","21:30"],["21:30","22:00"],["22:00","22:30"],["22:30","23:00"],["23:00","23:30"],["23:30","24:00"]]

(3)时间区间为对象

let timeArrays = new Array(48).fill(['', '']).map((item, index) => {
    let startVal = index * 30;
    let endVal = (index + 1) * 30;
    let startHour = Math.floor((startVal / 60));
    let startMinute = (startVal % 60);
    let endHour = Math.floor((endVal / 60));
    let endMinute = (endVal % 60);
    let startTime = ((startHour < 10) ? ('0' + startHour) : startHour) + ':' + (startMinute === 0 ? '00' : startMinute);
    let endTime = ((endHour < 10) ? ('0' + endHour) : endHour) + ':' + (endMinute === 0 ? '00' : endMinute);
    
    return {
        start: startTime,
        end: endTime
    };
});
console.log(JSON.stringify(timeArrays));

生成的时间区间如下:

[{"start":"00:00","end":"00:30"},{"start":"00:30","end":"01:00"},{"start":"01:00","end":"01:30"},{"start":"01:30","end":"02:00"},{"start":"02:00","end":"02:30"},{"start":"02:30","end":"03:00"},{"start":"03:00","end":"03:30"},{"start":"03:30","end":"04:00"},{"start":"04:00","end":"04:30"},{"start":"04:30","end":"05:00"},{"start":"05:00","end":"05:30"},{"start":"05:30","end":"06:00"},{"start":"06:00","end":"06:30"},{"start":"06:30","end":"07:00"},{"start":"07:00","end":"07:30"},{"start":"07:30","end":"08:00"},{"start":"08:00","end":"08:30"},{"start":"08:30","end":"09:00"},{"start":"09:00","end":"09:30"},{"start":"09:30","end":"10:00"},{"start":"10:00","end":"10:30"},{"start":"10:30","end":"11:00"},{"start":"11:00","end":"11:30"},{"start":"11:30","end":"12:00"},{"start":"12:00","end":"12:30"},{"start":"12:30","end":"13:00"},{"start":"13:00","end":"13:30"},{"start":"13:30","end":"14:00"},{"start":"14:00","end":"14:30"},{"start":"14:30","end":"15:00"},{"start":"15:00","end":"15:30"},{"start":"15:30","end":"16:00"},{"start":"16:00","end":"16:30"},{"start":"16:30","end":"17:00"},{"start":"17:00","end":"17:30"},{"start":"17:30","end":"18:00"},{"start":"18:00","end":"18:30"},{"start":"18:30","end":"19:00"},{"start":"19:00","end":"19:30"},{"start":"19:30","end":"20:00"},{"start":"20:00","end":"20:30"},{"start":"20:30","end":"21:00"},{"start":"21:00","end":"21:30"},{"start":"21:30","end":"22:00"},{"start":"22:00","end":"22:30"},{"start":"22:30","end":"23:00"},{"start":"23:00","end":"23:30"},{"start":"23:30","end":"24:00"}]

3、时间跨度任意指定

除了常见的时间跨度为60分钟或者30分钟,有的时候还可能需要其他的时间跨度,那么是否可能写一个相对通用的方法,参数为时间跨度(以分钟为单位),当然是可以的,具体实现代码如下(这里仅生成时间区间为字符串的,其他格式参考上面):

function generateTimes(step) {
    let size = Math.floor(24 * 60 / step);
    let timeArrays = new Array(size).fill('').map((item, index) => {
        let startVal = index * step;
        let endVal = (index + 1) * step;
        let startHour = Math.floor((startVal / 60));
        let startMinute = (startVal % 60);
        let endHour = Math.floor((endVal / 60));
        let endMinute = (endVal % 60);
        let startTime = ((startHour < 10) ? ('0' + startHour) : startHour) + ':' + (startMinute === 0 ? '00' : startMinute);
        let endTime = ((endHour < 10) ? ('0' + endHour) : endHour) + ':' + (endMinute === 0 ? '00' : endMinute);
    
        return startTime + ' - ' + endTime;
    });

    return timeArrays;
}

比如想要生成时间跨度为120分钟的时间区间,可以直接传入120即可

console.log(generateTimes(120));

生成的时间区间如下:

['00:00 - 02:00', '02:00 - 04:00', '04:00 - 06:00', '06:00 - 08:00', '08:00 - 10:00', '10:00 - 12:00', '12:00 - 14:00', '14:00 - 16:00', '16:00 - 18:00', '18:00 - 20:00', '20:00 - 22:00', '22:00 - 24:00']

需要注意的是,如果时间跨度无法被整除,那么生成的时间区间可能无法完全覆盖24小时。

到此这篇关于javascript自动生成24小时时间区间的文章就介绍到这了,更多相关JS时间区间内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: JavaScript自动生成24小时时间区间

本文链接: https://www.lsjlt.com/news/150963.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • JavaScript自动生成24小时时间区间
    目录1、时间跨度为60分钟(1)时间区间为字符串(2)时间区间为数组(3)时间区间为对象2、时间跨度为30分钟(1)时间区间为字符串(2)时间区间为数组(3)时间区间为对象3、时间跨...
    99+
    2024-04-02
  • 使用MySQL生成最近24小时整点时间临时表
    目录生成最近24小时整点生成最近30天生成最近12个月总结 生成最近24小时整点 SELECT -- 每向下推1行, @i比上次减去1 b.*, i.*, DATE_FORMAT( DA...
    99+
    2024-01-29
    mysql 生成临时表 sql临时表的使用 mysql 临时表
  • php如何获取时间戳转换成24小时制
    本篇内容主要讲解“php如何获取时间戳转换成24小时制”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“php如何获取时间戳转换成24小时制”吧!在php中可以通过date函数将时间戳转换成24小时...
    99+
    2023-06-20
  • win7 24小时制时间怎么更改
    本篇内容介绍了“win7 24小时制时间怎么更改”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!win724小时制时间更改教程首先我们在屏幕左...
    99+
    2023-07-01
  • mysql怎么修改字段自动生成时间
    小编给大家分享一下mysql怎么修改字段自动生成时间,希望大家阅读完这篇文章后大所收获,下面让我们一起去探讨吧!mysql修改字段自动生成时间的方法:1、添加CreateTime设置默认时间;2、修改Cre...
    99+
    2024-04-02
  • python时间生成方式
    第一版 #coding=utf-8 import time def get_year_mon_day(): time_array = time.localtime() result= u"%s 年 %s 月 %s 日" %...
    99+
    2023-01-31
    方式 时间 python
  • sql 取当前时间前24小时之内的数据
    1.先查一下现在时间和24小时前的时间 SELECT NOW(), DATE_FORMAT(DATE_SUB(NOW(), INTERVAL 24 HOUR),'%Y-%m-%d %H:%i:%S') AS '24小时前'  ...
    99+
    2023-09-27
    mysql sql 数据库
  • php随机生成某个时间段内的时间
    php生成指定范围内单个的时间戳 调用方法: php生成指定范围内多个随机的时间 函数调用方法: 输出结果: array(5) { [0]=> string(19) "2020-04-21 04:04:47" [1]=> s...
    99+
    2023-09-21
    php 开发语言
  • PHP怎么生成时间戳
    这篇“PHP怎么生成时间戳”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“PHP怎么生成时间戳”文章吧。首先,让我们来看一下 ...
    99+
    2023-07-05
  • MySQL8如何设置自动创建时间和自动更新时间
    这篇文章主要介绍“MySQL8如何设置自动创建时间和自动更新时间”,在日常操作中,相信很多人在MySQL8如何设置自动创建时间和自动更新时间问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”MySQL8如何设置自...
    99+
    2023-07-05
  • PHP如何生成时间戳?php时间戳怎么查询
    PHP 时间戳查询是一种在 PHP 编程语言中使用的日期和时间处理方式。 时间戳是指自 1970 年 1 月 1 日之后所经过的秒数,通常用于表示某个事件发生的时间或日期。通过使用 PHP 时间戳查询,您可以方便地获取特定的日期和时间,对于...
    99+
    2023-05-14
    php
  • mybatis-plus 自动填充创建时间/更新时间
    方式一:数据库级别 创建时间create_time字段设置类型为timestamp,默认值为CURRENT_TIMESTAMP; 更新时间update_time字段设置类型为timestamp,默认值为CURRENT_TIMESTAMP,勾...
    99+
    2023-08-17
    mybatis java mysql
  • java怎么生成特定时间
    要在Java中生成特定时间,可以使用`java.util.Calendar`类或`java.time.LocalTime`类。使用`...
    99+
    2023-09-26
    java
  • mybatis-plus自动填充插入更新时间有8小时时差
    今天使用mybatis-plus自动填充插入和更新时间有8小时时差 后来发现只需要修改一下mybaits连接的url即可 原先我是用的 datasource: ...
    99+
    2024-04-02
  • JavaScript如何生成指定范围的时间列表
    这篇文章将为大家详细讲解有关JavaScript如何生成指定范围的时间列表,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。准备 date对象有很多的方法,用到了以下: &n...
    99+
    2024-04-02
  • MySQL8设置自动创建时间和自动更新时间的实现方法
    目录业务场景:功能实现:DDL 脚本语法:1、新增字段create_time语法2、修改字段create_time语法3、新增字段update_time 语法4、修改字段update_time 语法总结业务场景: 1、在...
    99+
    2023-03-09
    mysql8自动创建时间和自动更新时间 mysql自动生成创建时间 mysql 自动更新时间
  • MySQL怎么查询Binlog生成时间
    这篇文章主要介绍“MySQL怎么查询Binlog生成时间”,在日常操作中,相信很多人在MySQL怎么查询Binlog生成时间问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”MySQL怎么查询Binlog生成时间...
    99+
    2023-07-05
  • MySQL如何查询Binlog 生成时间
    目录前言脚本介绍使用案例1. 查询 binlog index 文件2. 使用脚本查询时间前言 本篇文章介绍如何查询 Binlog 的生成时间。云上 RDS 有日志管理,但是自建实例没有,该脚本可用于自建实例闪回定位 Bi...
    99+
    2023-03-19
    mysql查询Binlog
  • MySQL如何查询Binlog生成时间
    目录前言脚本介绍使用案例1. 查询 binlog index 文件2. 使用脚本查询时间前言 本篇文章介绍如何查询 Binlog 的生成时间。云上 RDS 有日志管理,但是自建实例没...
    99+
    2023-03-19
    mysql查询Binlog 生成时间 mysql查询Binlog
  • c语音怎么生成时间戳
    在C语言中生成时间戳可以使用time.h头文件中的time()函数。具体代码如下: #include <stdio.h>...
    99+
    2024-03-07
    c语音
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作