在 Javascript 中解析 ISO 8601 日期

IT技术 javascript datetime formatting iso8601
2021-02-10 10:37:00

需要将具有以下结构的 ISO 8601 日期转换为 javascript 的帮助/提示。

CCYY-MM-DDThh:mm:ssTZD

我想像这样格式化日期:

January 28, 2011 - 7:30PM EST

我想保持这个解决方案尽可能干净和最小。

6个回答

Date 对象处理 8601 作为它的第一个参数:

var d = new Date("2014-04-07T13:58:10.104Z");
console.log(d.toString());

不适用于 IE 9:Quirks 模式。我们中的一些人需要浏览器兼容性。
2021-03-18 10:37:00
在 ES5 之前,日期解析依赖于实现。旧浏览器将显示不一致的结果。
2021-03-19 10:37:00
并非在所有浏览器中。请记住,ECMA 规范曾经或仍然对 Date() 的参数格式含糊不清。这就是为什么即使 IE11 也无法处理您的建议。
2021-03-30 10:37:00
@RenéStalder 也刚刚在 Win7 上的 IE9 中进行了测试,它也可以在那里工作。事实上,到目前为止我还没有找到一个不支持它的浏览器。
2021-03-30 10:37:00
@RenéStalder 我实际上只是在 IE11 中测试了它并且它有效。你在其他IE版本中测试过吗?
2021-04-02 10:37:00

datejs可以解析以下内容,您可能想尝试一下。

Date.parse('1997-07-16T19:20:15')           // ISO 8601 Formats
Date.parse('1997-07-16T19:20:30+01:00')     // ISO 8601 with Timezone offset

编辑:正则表达式版本

x = "2011-01-28T19:30:00EST"

MM = ["January", "February","March","April","May","June","July","August","September","October","November", "December"]

xx = x.replace(
    /(\d{4})-(\d{2})-(\d{2})T(\d{2}):(\d{2}):\d{2}(\w{3})/,
    function($0,$1,$2,$3,$4,$5,$6){
        return MM[$2-1]+" "+$3+", "+$1+" - "+$4%12+":"+$5+(+$4>12?"PM":"AM")+" "+$6
    }
)

结果

January 28, 2011 - 7:30PM EST

Edit2:我将时区更改为 EST,现在我得到了关注

x = "2011-01-28T19:30:00-05:00"

MM = {Jan:"January", Feb:"February", Mar:"March", Apr:"April", May:"May", Jun:"June", Jul:"July", Aug:"August", Sep:"September", Oct:"October", Nov:"November", Dec:"December"}

xx = String(new Date(x)).replace(
    /\w{3} (\w{3}) (\d{2}) (\d{4}) (\d{2}):(\d{2}):[^(]+\(([A-Z]{3})\)/,
    function($0,$1,$2,$3,$4,$5,$6){
        return MM[$1]+" "+$2+", "+$3+" - "+$4%12+":"+$5+(+$4>12?"PM":"AM")+" "+$6 
    }
)

返回

January 28, 2011 - 7:30PM EST

基本上

String(new Date(x))

返回

Fri Jan 28 2011 19:30:00 GMT-0500 (EST)

正则表达式部分只是将上面的字符串转换为您需要的格式。

January 28, 2011 - 7:30PM EST
@Slythic,已更新,如果有任何错误,请告诉我。
2021-03-12 10:37:00
我正在制作一个小部件,如果我可以拥有一个可以放入我的 JS 文件的简单函数,我会更喜欢。我认为 datajs 对此可能有点矫枉过正?感谢您的建议和快速回复!!
2021-03-28 10:37:00
@Slythic,然后我会写正则表达式,请稍等。
2021-03-31 10:37:00
嗯...没有按预期工作。我之前应该添加这个!以下是返回日期的示例:“2011-01-28T19:30:00-05:00”
2021-04-04 10:37:00
啊,好的,时区不是字符串,让我弄清楚如何解析它。
2021-04-05 10:37:00

如果你想保持简单,这应该足够了:

function parseIsoDatetime(dtstr) {
    var dt = dtstr.split(/[: T-]/).map(parseFloat);
    return new Date(dt[0], dt[1] - 1, dt[2], dt[3] || 0, dt[4] || 0, dt[5] || 0, 0);
}

注意parseFloat 是必须的, parseInt 并不总是有效。地图需要 IE9 或更高版本。

适用于格式:

  • 2014-12-28 15:30:30
  • 2014-12-28T15:30:30
  • 2014-12-28

对时区无效,请参阅有关这些的其他答案。

+1 简单便携。我进行了此更改以将日期解释为 UTC:return new Date(Date.UTC(dt[0], dt[1] - 1, dt[2], dt[3] || 0, dt[4] || 0, dt[5] || 0, 0));
2021-03-19 10:37:00
唉,IE11 Enterprise(基本上是IE8)不支持地图。呻吟
2021-03-19 10:37:00
处理最重要部分的非常好的小功能:修复那个当月索引。
2021-03-24 10:37:00
找到了一个 polyfill,它也适用于 IE8(只需将 .map 更改为 .myMap): Array.prototype.myMap = function(callbackFn) { var arr = []; for (var i = 0; i < this.length; i++) { arr.push(callbackFn(this[i], i, this)); } return arr; }
2021-04-11 10:37:00

也许,您可以使用 moment.js,在我看来,它是解析、格式化和处理客户端日期的最佳 JavaScript 库。你可以使用类似的东西:

var momentDate = moment('1890-09-30T23:59:59+01:16:20', 'YYYY-MM-DDTHH:mm:ss+-HH:mm:ss');
var jsDate = momentDate.toDate();

// Now, you can run any JavaScript Date method

jsDate.toLocaleString();

使用像 moment.js 这样的库的优势在于,即使在 IE 8+ 等传统浏览器中,您的代码也能完美运行。

这是有关解析方法的文档:https ://momentjs.com/docs/#/parsing/

根据MSDN,JavaScript Date 对象不提供任何特定的日期格式化方法(正如您在其他编程语言中看到的那样)。但是,您可以使用一些Date方法和格式来实现您的目标:

function dateToString (date) {
  // Use an array to format the month numbers
  var months = [
    "January",
    "February",
    "March",
    ...
  ];

  // Use an object to format the timezone identifiers
  var timeZones = {
    "360": "EST",
    ...
  };

  var month = months[date.getMonth()];
  var day = date.getDate();
  var year = date.getFullYear();

  var hours = date.getHours();
  var minutes = date.getMinutes();
  var time = (hours > 11 ? (hours - 11) : (hours + 1)) + ":" + minutes + (hours > 11 ? "PM" : "AM");
  var timezone = timeZones[date.getTimezoneOffset()];

  // Returns formatted date as string (e.g. January 28, 2011 - 7:30PM EST)
  return month + " " + day + ", " + year + " - " + time + " " + timezone;
}

var date = new Date("2011-01-28T19:30:00-05:00");

alert(dateToString(date));

您甚至可以更进一步并覆盖该Date.toString()方法:

function dateToString () { // No date argument this time
  // Use an array to format the month numbers
  var months = [
    "January",
    "February",
    "March",
    ...
  ];

  // Use an object to format the timezone identifiers
  var timeZones = {
    "360": "EST",
    ...
  };

  var month = months[*this*.getMonth()];
  var day = *this*.getDate();
  var year = *this*.getFullYear();

  var hours = *this*.getHours();
  var minutes = *this*.getMinutes();
  var time = (hours > 11 ? (hours - 11) : (hours + 1)) + ":" + minutes + (hours > 11 ? "PM" : "AM");
  var timezone = timeZones[*this*.getTimezoneOffset()];

  // Returns formatted date as string (e.g. January 28, 2011 - 7:30PM EST)
  return month + " " + day + ", " + year + " - " + time + " " + timezone;
}

var date = new Date("2011-01-28T19:30:00-05:00");
Date.prototype.toString = dateToString;

alert(date.toString());