业务是需要根据时间查询数据,并且进入页面,时间选择器默认显示的值是今天凌晨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"参数,不知道为什么就是没效果,也许是使用方法的问题。
至此,问题解决。
欢迎指正,补充和讨论!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)