在浏览器窗口中自动转换日期

时间:2019-01-03 00:34:47

标签: javascript mysql node.js express handlebars.js

在我正在工作的网站的前端打印日期时,我目前遇到问题。该日期是通过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              
        } );
    } );
} );

在此先感谢任何愿意帮助我解决这个难题的人。 祝你有美好的一天。

1 个答案:

答案 0 :(得分:1)

数据库使用ISO DateTime格式存储时间戳,这是非常标准且安全的。将此时间戳记入JS Date构造函数中不应导致任何类型的转换。

但是,当调用Date对象的toString()方法时,通常会通过考虑本地计算机的时区偏移来生成时间戳。时区也会在时间戳的末尾添加。

因此,据我所知,这可能不是服务器端的问题,而是应该检查在浏览器中运行的客户端应用程序的代码。

如果要在客户端输出与服务器端完全相同的时间戳,请使用Date.toISOString()方法。