我想在JavaScript中解析一个没有时区的日期。我试着:
new Date(Date.parse("2005-07-08T00:00:00+0000"));
返回2005年7月8日星期五02:00:00 GMT+0200(中欧夏令时):
new Date(Date.parse("2005-07-08 00:00:00 GMT+0000"));
返回相同的结果,并且:
new Date(Date.parse("2005-07-08 00:00:00 GMT-0000"));
也返回相同的结果。
我想解析时间:
没有时区。
而不调用构造函数Date。UTC或new日期(年、月、日)。
通过简单地将一个字符串传递到Date构造函数(没有原型方法)。
我必须生成一个Date对象,而不是String对象。
因为它确实是一个格式问题时显示日期(例如显示在本地时间),我喜欢使用新的(ish) Intl。DateTimeFormat对象来执行格式化,因为它更显式,并提供更多输出选项:
const dateOptions = { timeZone: 'UTC', month: 'long', day: 'numeric', year: 'numeric' };
const dateFormatter = new Intl.DateTimeFormat('en-US', dateOptions);
const dateAsFormattedString = dateFormatter.format(new Date('2019-06-01T00:00:00.000+00:00'));
console.log(dateAsFormattedString) // "June 1, 2019"
如所示,通过将timeZone设置为“UTC”,它将不会执行本地转换。作为奖励,它还允许您创建更精致的输出。你可以阅读更多关于国际。DateTimeFormat对象。
无需创建新的Intl就可以实现相同的功能。DateTimeFormat对象。简单地将语言环境和日期选项直接传递给toLocaleDateString()函数。
const dateOptions = { timeZone: 'UTC', month: 'long', day: 'numeric', year: 'numeric' };
const myDate = new Date('2019-06-01T00:00:00.000+00:00');
myDate.toLocaleDateString('en-US', dateOptions); // "June 1, 2019"
这是我想出的解决这个问题的方法,对我来说很有效。
图书馆使用:momentjs与简单的javascript日期类。
步骤1。
将字符串日期转换为moment对象(PS:只要未调用toDate()方法,moment将保留原始日期和时间):
const dateMoment = moment("2005-07-08T11:22:33+0000");
步骤2。
从之前创建的moment对象中提取小时和分钟值:
const hours = dateMoment.hours();
const mins = dateMoment.minutes();
步骤3。
将时间转换为日期(PS:这将根据浏览器/机器的时区更改原始日期,但不要担心,请阅读第4步):
const dateObj = dateMoment.toDate();
步骤4。
手动设置步骤2中提取的小时和分钟。
dateObj.setHours(hours);
dateObj.setMinutes(mins);
第5步。
dateObj现在将显示原始日期,没有任何时区差异。即使日光时间的变化也不会对日期对象产生任何影响,因为我们手动设置了原始的小时和分钟。
希望这能有所帮助。