我见过JSON日期格式的许多不同标准:

"\"\\/Date(1335205592410)\\/\""         .NET JavaScriptSerializer
"\"\\/Date(1335205592410-0500)\\/\""    .NET DataContractJsonSerializer
"2012-04-23T18:25:43.511Z"              JavaScript built-in JSON object
"2012-04-21T18:25:43-05:00"             ISO 8601

哪一个是正确的?还是最好的?这方面有什么标准吗?


当前回答

来自RFC 7493(I-JSON消息格式):

I-JSON代表Internet JSON或互操作JSON,具体取决于您询问的对象。

协议通常包含设计用于包含时间戳或持续时间。建议所有此类数据按照规定,项目以ISO 8601格式表示为字符串值在RFC 3339中,附加的限制是大写不包括时区默认值,并且即使在它们的值为“00”。还建议所有数据项包含持续时间符合RFC 3339的附录A,具有相同的附加限制。

其他回答

首选的方法是使用2018-04-23T18:25:43.511Z。。。

下图显示了为什么这是首选方式:

因此,正如您所看到的,Date有一个原生的方法toJSON,它以这种格式返回,并且可以很容易地再次转换为Date。。。

如果有疑问,只需按F12(在Firefox中为Ctrl+Shift+K)进入现代浏览器的javascript web控制台,并编写以下内容:

new Date().toISOString()

将输出:

“2019-07-04T13:33:03.969Z”

大大!!

JSON对日期一无所知。.NET所做的是非标准的黑客/扩展。

我会使用一种可以很容易地转换为JavaScript中的Date对象的格式,即可以传递给新的Date(…)的格式。最简单也是最可移植的格式是1970年以来包含毫秒的时间戳。

我认为这确实取决于用例。在许多情况下,使用适当的对象模型(而不是将日期呈现为字符串)可能更为有益,如下所示:

{
"person" :
      {
 "name" : {
   "first": "Tom",
   "middle": "M",
  ...
}
 "dob" :  {
         "year": 2012,
         "month": 4,
         "day": 23,
         "hour": 18,
         "minute": 25,
         "second": 43,
         "timeZone": "America/New_York"
    }   
   }
}

诚然,这比RFC 3339更冗长,但:

它也是人类可读的它实现了一个适当的对象模型(如在OOP中,只要JSON允许)它支持时区(而不仅仅是给定日期和时间的UTC偏移量)它可以支持更小的单位,如毫秒、纳秒。。。或者仅仅是小数秒它不需要单独的解析步骤(解析日期时间字符串),JSON解析器将为您完成一切轻松创建任何日期时间框架或任何语言的实现可以轻松扩展以支持其他日历刻度(希伯来文、中文、伊斯兰…)和时代(公元前、公元前…)10000年是安全的;-)(RFC 3339不是)支持全天日期和浮动时间(Javascript的Date.toJSON()不支持)

我不认为将日期序列化为JSON时真正需要正确的排序(如RFC 3339的funroll所指出的)。同样,这仅适用于具有相同时区偏移的日期时间。

这是我的工作与解析服务器

{
    "ContractID": "203-17-DC0101-00003-10011",
    "Supplier":"Sample Co., Ltd",
    "Value":12345.80,
    "Curency":"USD",
    "StartDate": {
                "__type": "Date",
                "iso": "2017-08-22T06:11:00.000Z"
            }
}