抛出问题
在开发中返回前端数据的时候,如果时间格式不做处理的话,前端拿到的数据,时间格式是如下图所示的:
方式一:前台转换
在用Layui做写后台页面的时候,用layui提供的一个工具转化也是可以的
templet: '<div>{{ layui.laytpl.toDateString(d.createTime) }}</div>'
这样操作会比较麻烦,除了每个时间上都要加方法转换外,也降低了代码的可阅读行
除了在前台转化转换之后,其实还可以在后台转换好时间格式,再返回给前台
方式二:后台转换
1. 返回实体类时
在对应实体类的时间字段上面加上如下注解,那么返回的时间格式就自动转换成了需要的格式了。
import com.fasterxml.jackson.annotation.JsonFormat;
...
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
private LocalDateTime createTime;
注意:
这种方式可能在返回时,时间不正确,可以尝试加上timezone=“GMT+8”
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss",timezone="GMT+8")
同时可以在配置文件中设置全局配置,这样不用在每个实体类时间字段上都加上注解了,properties配置如下:
//时间类型会直接返回格式时间
spring.jackson.date-format=yyyy-MM-dd HH:mm:ss
spring.jackson.time-zone=Asia/Shanghai
2. 返回MAP时
在sql语句里面可以使用 DATE_FORMAT函数直接把时间格式转换
SELECT DATE_FORMAT( b.book_start_time,'%Y-%m-%d %H:%i:%s') book_start_time
这时返回的时间格式就可以直接用了
"book_start_time": "2020-02-20 10:16:00",
"book_status": 0,
"parking_lot_address": "xx区",
"id": 27,
"book_parkinglot": "xxx停车场",
"book_end_time": "2020-02-21 10:16:00"