解决elmentui的时间选择器的选定时间与传给后端实际值相差8小时问题

解决elmentui的时间选择器的选定时间与传给后端实际值相差8小时问题,第1张

需求场景:

业务是需要根据时间查询数据,并且进入页面,时间选择器默认显示的值是今天凌晨0点到当前这个时间段
前端界面:

后端参数:

问题描述

因为是选取时间范围,我前端使用的是两个elmentui的DateTimePicker:

绑定的参数分别是startTime和endTime。

如上图所示,定义了两个参数,赋予初始值。理论上这样就行了,但是问题出现了。

时间选择器显示的时间是对的,但实际传参确是:

可以很明显看到显示的时间比传参时间多8个小时。
然而当我手动取选择时间时:


选择器显示时间和传参时间又是正常对得上的。

原因分析:

通过上面默认和手选 *** 作,观察时间选择器显示和传参时间,可以看到,手动在DateTimePicker选取的时间,传给后端的是GMT格式;而通过上面的代码设置的默认时间传给后端的是UTC格式。GMT和UTC本身就差八小时,典型的时区问题。
通过查阅ElmentUI官方文档,DateTimePicker是可以解析new Date()创建的时间的。从理论上讲,上面设置默认值的代码是合理的。但是却出现了显示和传值不一致问题,具体原因我想是elmentui的bug吧(坐等大佬剖析源码反驳)。
通过调试发现当手动选择时间时,传给绑定值得就是GMT格式。
所以,我们需要传一个GMT时间给绑定值。解决问题的方法就是在设置默认值时,用new Date()创建时间后,还要对时间进行转换,转为GMT格式。

解决方案:

新增一个时间转换方法,代码如下:

fomatTime(date) {
      if (date == "" || !date) {
        return "";
      }
      var _date = new Date(date);
      var y = _date.getFullYear();
      var m = _date.getMonth() + 1;
      m = m < 10 ? ('0' + m) : m;
      var d = _date.getDate();
      d = d < 10 ? ('0' + d) : d;
      var h = _date.getHours();
      h = h < 10 ? ('0' + h) : h;
      var minute = _date.getMinutes();
      minute = minute < 10 ? ('0' + minute) : minute;
      var second = _date.getSeconds();
      second = second < 10 ? ('0' + second) : second;
      return y + '-' + m + '-' + d + ' ' + h + ':' + minute + ':' + second ;
    }

在赋予初始值时

    this.startTime = this.fomatTime(this.getTodayBegin())
    this.endTime = this.fomatTime(new Date())

这样传给DateTimePicker的绑定值就是GMT格式的时间,传给后台也就是GMT格式

另外关于这个八小时时差问题在网上99%的解决方案是加一个value-format="yyyy-MM-dd HH:mm:ss"参数,不知道为什么就是没效果,也许是使用方法的问题。
至此,问题解决。
欢迎指正,补充和讨论!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/1297116.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-10
下一篇 2022-06-10

发表评论

登录后才能评论

评论列表(0条)

保存