我想在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对象。


当前回答

不幸的是,在默认情况下,日期解析有一些固有的问题没有得到很好的解决。

-人类可读的日期包含隐含的时区 网络上有许多广泛使用的日期格式是模棱两可的

为了简单明了地解决这些问题,我们需要这样一个函数:

>parse(whateverDateTimeString,expectedDatePattern,timezone)
"unix time in milliseconds"

我找过这个,但没有找到这样的东西!

所以我创造了: https://github.com/zsoltszabo/timestamp-grabber

享受吧!

其他回答

我个人更喜欢@wawka的答案,然而,我也提出了一个不那么干净的技巧来解决这个问题,这是更简单的,如果你确定你想转换的字符串的格式,可以工作。

请看下面的代码片段:

var dateString = 2021- 08-02t00 var dateObj =新日期(数据+ z) 日志控制台。 var dateObjWithTZ =新日期 log控制台(“正常转换:”,dateObjWithTZ)

这在这种情况下是有效的,因为在日期时间字符串的末尾添加Z将使JS将此字符串视为UTC日期字符串,因此它不会向其添加时区差异。

这是我想出的解决这个问题的方法,对我来说很有效。


图书馆使用: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现在将显示原始日期,没有任何时区差异。即使日光时间的变化也不会对日期对象产生任何影响,因为我们手动设置了原始的小时和分钟。

希望这能有所帮助。

日期被正确解析,只是toString将其转换为您的本地时区:

let s = "2005-07-08T11:22:33+0000"; let d = new Date(Date.parse(s)); //此日志为我 //“2005年7月8日星期五13:22:33 GMT+0200(中欧夏季时间)” //和其他东西给你 console.log (d.toString ()) //此日志 //星期五,2005年7月8日11:22:33 GMT // for everyone console.log (d.toUTCString ())

Javascript Date对象是时间戳-它们只包含从epoch开始的毫秒数。Date对象中没有时区信息。这个时间戳代表哪个日历日期(日、分、秒)是一个解释问题(其中一个是…字符串方法)。

上面的例子显示日期被正确地解析了——也就是说,它实际上包含了一个毫秒数,对应于GMT的"2005-07-08T11:22:33"。

因为它确实是一个格式问题时显示日期(例如显示在本地时间),我喜欢使用新的(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"

(新日期().toString())。替换(/ \w+-\d+ \(.*\)$/,"")

这将有输出:2018年7月10日星期二19:07:11

(新日期(“2005 - 07 - 08 - t11:22:33 + 0000”).toString())。替换(/ \w+-\d+ \(.*\)$/,"")

这将有输出:Fri july 08 2005 04:22:33

注意:返回的时间将取决于您的本地时区