Vue获取两个时间点之间的所有间隔时间

本文主要是介绍Vue获取两个时间点之间的所有间隔时间,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

这里我们使用的主要方法是new Date().setFullYear()设置当前的时间,如果传入的时间是new Date().setFullYear(2020,12,32),该方法会自动将时间转化为2021-1-1的时间戳 ,如果有一个参数超出了合理的范围,setFullYear 方法会更新其他参数值,日期对象的日期值也会被相应更新。 例如,为 monthValue指定 15, 则年份会加1,月份值会为3 ** MDN说明

我们在开发中经常遇到后端人员给的日期时间格式不是标准的,需要我们前端人员来处理。
例如:
在这里插入图片描述
处理后:

console.log(new Date('2022-05-31T05:47:41Z').toLocaleString())

在这里插入图片描述

1,获取两个时间之间的 间隔时间

在这里插入图片描述
代码如下:

/** 获取两个时间之间的 间隔时间* @param { Date | number | string } startTime 开始时间 字符串格式(6:00 06:00 18:00, 18:00:00) 必须是24小时格式* @param { Date | number | string } endTime 结束时间 字符串格式(6:00 06:00 18:00, 18:00:00) 必须是24小时格式*/
export function getBetweenTime(startTime: string, endTime: string): Array<string> {// 校验时间格式if (typeof startTime === 'string' && typeof endTime === 'string') {const reg = /^(0?[1-9]|([1-2][0-4])):(([0-5][0-9])(:([0-9][0-9]))?)$/if (!reg.test(startTime)) throw `开始时间:${startTime} 时间格式错误`if (!reg.test(endTime)) throw `结束时间:${endTime} 时间格式错误`} else throw `${startTime} 或者 ${endTime} 时间格式错误`let start: number = +startTime.split(':')[0]let end: number = +endTime.split(':')[0]const resultTime: string[] = []// 当 开始时间小于结束时间的时候进入循环while (start <= end) {// 拼接时间格式 自动给 小于10的时间前面补0let setTime = start >= 10 ? `${start}:00` : `0${start}:00`resultTime.push(setTime)// 重新设置开始时间start += 1}return resultTime
}

2,获取两个日期之间的间隔日期

在这里插入图片描述

/** 获取两个日期之间的间隔日期* @param { Date | number | string } startTime 开始时间 标准时间格式 时间戳格式 字符串格式(2008-08-08,2008-8-8,2008-08-8,2008-8-08)* @param { Date | number | string } endTime 结束时间 标准时间格式 时间戳格式 字符串格式(2008-08-08,2008-8-8,2008-08-8,2008-8-08)*  */
export function getBetweenDate(startTime: Date | number | string,endTime: Date | number | string
): Array<string> {// 校验时间格式if (typeof startTime === 'string') {const reg = /^\d{4}-(0?[1-9]|1[0-2])-((0?[1-9])|((1|2)[0-9])|30|31)$/gif (!reg.test(startTime)) throw `开始时间:${startTime}时间格式错误`}if (typeof endTime === 'string') {const reg = /^\d{4}-(0?[1-9]|1[0-2])-((0?[1-9])|((1|2)[0-9])|30|31)$/gif (!reg.test(endTime)) throw `结束时间:${endTime}时间格式错误`}let start: Date = new Date(startTime)let end: Date = new Date(endTime)const resultTime: string[] = []// 当 开始时间小于结束时间的时候进入循环while (start <= end) {let getDay = start.getDate()// 月份需要加 1let getMonth = start.getMonth() + 1let getYear = start.getFullYear()/*** 拼接时间格式* (getMonth >= 10 ? `${getMonth}` : `0${getMonth}`) 自动给 小于10的时间前面补0*/let setTime =`${getYear}-` +(getMonth >= 10 ? `${getMonth}` : `0${getMonth}`) +'-' +(getDay >= 10 ? `${getDay}` : `0${getDay}`)resultTime.push(setTime)/*** 重新设置开始时间* 使用 setFullYear() 方法会自动将时间累加,返回的是时间戳格式* 使用 new Date() 将时间重新设置为标准时间* getMonth - 1 将月份时间重新还原*/start = new Date(start.setFullYear(getYear, getMonth - 1, getDay + 1))}return resultTime
}

3,获取指定两个月份之间的 间隔月份

在这里插入图片描述

/*** 获取指定两个月份之间的 间隔月份* @param { Date | number | string } startTime 开始时间 标准时间格式 时间戳格式 字符串格式(2008-08,2008-8)* @param { Date | number | string } endTime 结束时间 标准时间格式 时间戳格式 字符串格式(2008-08,2008-8)*/
export function getBetweenMonth(startTime: Date | number | string,endTime: Date | number | string
): Array<string> {// 校验时间格式if (typeof startTime === 'string') {const reg = /^\d{4}-(0?[1-9]|1[0-2])$/gif (!reg.test(startTime)) throw `开始时间:${startTime}时间格式错误`}if (typeof endTime === 'string') {const reg = /^\d{4}-(0?[1-9]|1[0-2])$/gif (!reg.test(endTime)) throw `结束时间:${endTime}时间格式错误`}let start: Date = new Date(startTime)let end: Date = new Date(endTime)const resultTime: string[] = []// 当 开始时间小于结束时间的时候进入循环while (start <= end) {// 月份需要加 1let getMonth = start.getMonth() + 1let getYear = start.getFullYear()/*** 拼接时间格式* (getMonth >= 10 ? `${getMonth}` : `0${getMonth}`) 自动给 小于10的时间前面补0*/let setTime = `${getYear}-` + (getMonth >= 10 ? `${getMonth}` : `0${getMonth}`)resultTime.push(setTime)/*** 重新设置开始时间* 使用 setFullYear() 方法会自动将时间累加,返回的是时间戳格式* 使用 new Date() 将时间重新设置为标准时间*/start = new Date(start.setFullYear(getYear, getMonth))}return resultTime
}

4,获取两个年份时间点 之间的间隔年份

在这里插入图片描述

/** 获取两个年份时间点 之间的间隔年份* @param { Date | number | string } startTime 开始时间 标准时间格式 时间戳格式 字符串格式(2008)* @param { Date | number | string } endTime 结束时间 标准时间格式 时间戳格式 字符串格式(2008)*/
export function getBetweenYear(startTime: Date | number | string,endTime: Date | number | string
): Array<string> {// 校验时间格式if (typeof startTime === 'string') {const reg = /^\d{4}$/gif (!reg.test(startTime)) throw `开始时间:${startTime}时间格式错误`}if (typeof endTime === 'string') {const reg = /^\d{4}$/gif (!reg.test(endTime)) throw `结束时间:${endTime}时间格式错误`}let start: Date = new Date(startTime)let end: Date = new Date(endTime)const resultTime: string[] = []// 当 开始时间小于结束时间的时候进入循环while (start <= end) {let getYear = start.getFullYear()// 拼接时间格式let setTime = `${getYear}`resultTime.push(setTime)/*** 重新设置开始时间* 使用 setFullYear() 方法会自动将时间累加,返回的是时间戳格式* 使用 new Date() 将时间重新设置为标准时间*/start = new Date(start.setFullYear(getYear + 1))}return resultTime
}

这篇关于Vue获取两个时间点之间的所有间隔时间的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/430255

相关文章

HTML5 中的<button>标签用法和特征

《HTML5中的<button>标签用法和特征》在HTML5中,button标签用于定义一个可点击的按钮,它是创建交互式网页的重要元素之一,本文将深入解析HTML5中的button标签,详细介绍其属... 目录引言<button> 标签的基本用法<button> 标签的属性typevaluedisabled

HTML5实现的移动端购物车自动结算功能示例代码

《HTML5实现的移动端购物车自动结算功能示例代码》本文介绍HTML5实现移动端购物车自动结算,通过WebStorage、事件监听、DOM操作等技术,确保实时更新与数据同步,优化性能及无障碍性,提升用... 目录1. 移动端购物车自动结算概述2. 数据存储与状态保存机制2.1 浏览器端的数据存储方式2.1.

基于 HTML5 Canvas 实现图片旋转与下载功能(完整代码展示)

《基于HTML5Canvas实现图片旋转与下载功能(完整代码展示)》本文将深入剖析一段基于HTML5Canvas的代码,该代码实现了图片的旋转(90度和180度)以及旋转后图片的下载... 目录一、引言二、html 结构分析三、css 样式分析四、JavaScript 功能实现一、引言在 Web 开发中,

SpringMVC高效获取JavaBean对象指南

《SpringMVC高效获取JavaBean对象指南》SpringMVC通过数据绑定自动将请求参数映射到JavaBean,支持表单、URL及JSON数据,需用@ModelAttribute、@Requ... 目录Spring MVC 获取 JavaBean 对象指南核心机制:数据绑定实现步骤1. 定义 Ja

Python打印对象所有属性和值的方法小结

《Python打印对象所有属性和值的方法小结》在Python开发过程中,调试代码时经常需要查看对象的当前状态,也就是对象的所有属性和对应的值,然而,Python并没有像PHP的print_r那样直接提... 目录python中打印对象所有属性和值的方法实现步骤1. 使用vars()和pprint()2. 使

CSS place-items: center解析与用法详解

《CSSplace-items:center解析与用法详解》place-items:center;是一个强大的CSS简写属性,用于同时控制网格(Grid)和弹性盒(Flexbox)... place-items: center; 是一个强大的 css 简写属性,用于同时控制 网格(Grid) 和 弹性盒(F

CSS实现元素撑满剩余空间的五种方法

《CSS实现元素撑满剩余空间的五种方法》在日常开发中,我们经常需要让某个元素占据容器的剩余空间,本文将介绍5种不同的方法来实现这个需求,并分析各种方法的优缺点,感兴趣的朋友一起看看吧... css实现元素撑满剩余空间的5种方法 在日常开发中,我们经常需要让某个元素占据容器的剩余空间。这是一个常见的布局需求

CSS Anchor Positioning重新定义锚点定位的时代来临(最新推荐)

《CSSAnchorPositioning重新定义锚点定位的时代来临(最新推荐)》CSSAnchorPositioning是一项仍在草案中的新特性,由Chrome125开始提供原生支持需... 目录 css Anchor Positioning:重新定义「锚定定位」的时代来了! 什么是 Anchor Pos

CSS中的Static、Relative、Absolute、Fixed、Sticky的应用与详细对比

《CSS中的Static、Relative、Absolute、Fixed、Sticky的应用与详细对比》CSS中的position属性用于控制元素的定位方式,不同的定位方式会影响元素在页面中的布... css 中的 position 属性用于控制元素的定位方式,不同的定位方式会影响元素在页面中的布局和层叠关

HTML5 getUserMedia API网页录音实现指南示例小结

《HTML5getUserMediaAPI网页录音实现指南示例小结》本教程将指导你如何利用这一API,结合WebAudioAPI,实现网页录音功能,从获取音频流到处理和保存录音,整个过程将逐步... 目录1. html5 getUserMedia API简介1.1 API概念与历史1.2 功能与优势1.3