el-date-picker选择时间后标准时间少1小时问题

问题

前端开发中发现Element的时间组件el-date-picker在选择选择部分时间后js对象的标准时间少1小时,如果选择的小时为0,会导致部分转换条件下结果少1天。

比如组件中选择的本地时间为:

1988-08-01 00:00:00

而js对象获取到是标准时间是:

1988-07-31T15:00:00.000Z

比熟悉的概念1988-07-31T16:00:00.000Z少了1小时

解读

经过el组件多次选择不同日期,发现这个现象在1988年9月11、12日有不同的效果:

页面上选择1988年9月11(标准时间9月10下午)就会少1小时

1988年9月12以及之后(标准时间9月11下午)就不会少。

进一步查此日期前后的事件,发现该日期是当年夏令时的结束日期。1986年至1991年,我国在全国范围实行了六年夏令时 ,每年从4月中旬的第一个星期日2时整(北京时间)到9月中旬第一个星期日的凌晨2时整(北京夏令时)。夏令时_百度百科

而上述找到的分界点1988年9月11是当年夏令时的最后一天,因此出现了前一天标准时间少了1小时,后一天标准时间正常的情况。

为避免相关问题出现,在前后端开发中,尽量使用相同的时间格式化处理策略,多用开发语言提供的时间类或其他成熟的封装类,不要在时间对象提供的封装方法之外直接对数值做编辑(比如不要将时间对象转成标准时间后手动加减数值得到本地时间)。

相关推荐
月忆3643 分钟前
等待组(waitgroup)
前端·爬虫·python
令狐寻欢6 分钟前
HTML中 的 meta 标签常用属性及其作用
前端·html
SynthWriter11 分钟前
Trae 帮我生成了一个贪吃蛇的游戏,好玩儿
前端
超级土豆粉21 分钟前
JavaScript 标签加载
开发语言·javascript·ecmascript
用户214118326360224 分钟前
dify案例分享-Dify+RSS 聚合 8 大平台实时热点,新闻获取效率飙升 300%
前端
百锦再26 分钟前
Razor编程中@Html的方法使用大全
前端·html
啪叽29 分钟前
JavaScript可选链操作符(?.)的实用指南
前端·javascript
Ian在掘金30 分钟前
bat+python实现easy connect自动连接
前端·python
代码搬运媛32 分钟前
【react实战】如何实现监听窗口大小变化
前端·javascript·react.js
小桥风满袖35 分钟前
Three.js-硬要自学系列30之专项学习环境光
前端·css·three.js