在我正在工作的网站的前端打印日期时,我目前遇到问题。该日期是通过Node.js(mysql
模块)从MySql数据库中检索的,该日期以MySql DATETIME
格式存储。使用的视图引擎是“把手”。
问题在于日期在浏览器窗口中时会自动转换,而我目前无法确定发生在哪里以及如何发生。 Console.log记录了从节点数据库查询中检索到的“日期”字段,为我提供了2018-12-27T18:00:00.000Z
类型的日期,但是在浏览器中,该日期被打印为Thu Dec 27 2018 19:00:00 GMT+0000 (Coordinated Universal Time)
。我已经尝试在节点端进行date = date.toString()
转换,但无济于事。
-
这是node.js端的代码:
app.get( '/blog' , ( req , res ) => {
db.get().query( `SELECT * FROM posts` , ( error , results ) => {
res.render( "./blog.hbs" ,
{
pageTitle : "xx - My Blog" ,
posts : results
} );
} );
} );
在此先感谢任何愿意帮助我解决这个难题的人。 祝你有美好的一天。
答案 0 :(得分:1)
数据库使用ISO DateTime格式存储时间戳,这是非常标准且安全的。将此时间戳记入JS Date构造函数中不应导致任何类型的转换。
但是,当调用Date对象的toString()方法时,通常会通过考虑本地计算机的时区偏移来生成时间戳。时区也会在时间戳的末尾添加。
因此,据我所知,这可能不是服务器端的问题,而是应该检查在浏览器中运行的客户端应用程序的代码。
如果要在客户端输出与服务器端完全相同的时间戳,请使用Date.toISOString()方法。