我希望服务器始终在HTML中提供UTC日期,并在客户端站点上使用JavaScript将其转换为用户的本地时区.
如果我可以用户的区域设置日期格式输出,则可以获得奖励.
似乎从UTC日期开始最简单的方法是创建一个新Date
对象并使用这些setUTC…
方法将其设置为您想要的日期/时间.
然后各种toLocale…String
方法将提供本地化输出.
// This would come from the server.
// Also, this whole block could probably be made into an mktime function.
// All very bare here for quick grasping.
d = new Date();
d.setUTCFullYear(2004);
d.setUTCMonth(1);
d.setUTCDate(29);
d.setUTCHours(2);
d.setUTCMinutes(45);
d.setUTCSeconds(26);
console.log(d); // -> Sat Feb 28 2004 23:45:26 GMT-0300 (BRT)
console.log(d.toLocaleString()); // -> Sat Feb 28 23:45:26 2004
console.log(d.toLocaleDateString()); // -> 02/28/2004
console.log(d.toLocaleTimeString()); // -> 23:45:26
这个问题已经过时了,所以当时并不存在moment.js,但对于新项目,它简化了很多这样的任务.
最好从UTC 解析日期字符串,如下所示(在服务器上创建一个ISO-8601兼容字符串,以便在所有浏览器中获得一致的结果):
var m = moment("2013-02-08T09:30:26Z");
现在只需m
在您的应用程序中使用,moment.js默认为本地时区进行显示操作.有许多方法可以格式化日期和时间值或提取部分值.
您甚至可以在用户区域设置中格式化一个时刻对象,如下所示:
m.format('LLL') // Returns "February 8 2013 8:30 AM" on en-us
要将moment.js对象转换为不同的时区(即既不是本地时区也不是UTC),您将需要moment.js时区扩展.该页面还有一些示例,使用起来非常简单.
您可以使用new Date().getTimezoneOffset()/60
时区.还有toLocaleString()
一种使用用户的语言环境显示日期的方法.
以下是整个列表:使用日期
一旦构建了日期对象,这里就是转换的片段:
该函数采用UTC格式的Date对象和格式字符串.
你需要一个Date.strftime
原型.
function UTCToLocalTimeString(d, format) { if (timeOffsetInHours == null) { timeOffsetInHours = (new Date().getTimezoneOffset()/60) * (-1); } d.setHours(d.getHours() + timeOffsetInHours); return d.strftime(format); }
在JS中,除了如上所述转换每个属性之外,没有简单且跨平台的方法来格式化本地日期时间。
这是我用来获取本地YYYY-MM-DD的快速技巧。请注意,这是一个hack,因为最终日期将不再具有正确的时区(因此您必须忽略时区)。如果我还有其他需要,可以使用moment.js。
var d = new Date(); d = new Date(d.getTime() - d.getTimezoneOffset() * 60000) var yyyymmdd = t.toISOString().slice(0,0); // 2017-05-09T08:24:26.581Z (but this is not UTC)
d.getTimezoneOffset()返回以分钟为单位的时区偏移量,而d.getTime()以毫秒为单位,因此为x 60,000。
这是我在过去的项目中使用的内容:
var myDate = new Date(); var tzo = (myDate.getTimezoneOffset()/60)*(-1); //get server date value here, the parseInvariant is from MS Ajax, you would need to do something similar on your own myDate = new Date.parseInvariant('<%=DataCurrentDate%>', 'yyyyMMdd hh:mm:ss'); myDate.setHours(myDate.getHours() + tzo); //here you would have to get a handle to your span / div to set. again, I'm using MS Ajax's $get var dateSpn = $get('dataDate'); dateSpn.innerHTML = myDate.localeFormat('F');