实际上可以修改Date对象如何被序列化为JSON。结合reviver函数,可以创建一个双向解决方案,它将自动处理序列化,并且可以轻松用于反序列化。
首先修改这样的序列:
Date.prototype.toJSON = function() { return "{timestamp}+" . this.getTime() }
这将前缀改变Date对象的表示为Unix时间戳作为标记:
> json = JSON.stringify({test:new Date()});
"{"test":"{timestamp}1380164268633"}"
然后你就可以创建一个reviver功能,将自动过滤掉这些值:
function json_deserialize_helper(key,value) {
if (typeof value === 'string') {
var regexp;
regexp = /^{timestamp}(\d*)$/.exec(value);
if (regexp) {
return new Date(+regexp[1]);
}
}
return value;
}
(Credit :此代码已基本从这个答案抄在一个相关的问题:https://stackoverflow.com/a/14509447/2572897)
这种设置
现在,从之前我们的结果的反序列化将导致Date对象再次:
> JSON.parse(json, json_deserialize_helper);
Object {test: Thu Sep 26 2013 04:57:48 GMT+0200 (CEST)}
或者你可以选择不修改串行化而是使用正则表达式来捕捉标准序列化格式:
function json_deserialize_helper(key,value) {
if (typeof value === 'string') {
var regexp;
regexp = /^\d\d\d\d-\d\d-\d\dT\d\d:\d\d:\d\d.\d\d\dZ$/.exec(value);
if (regexp) {
return new Date(value);
}
}
return value;
}
实施例:
> json = JSON.stringify({test:new Date()})
"{"test":"2013-09-26T03:05:26.563Z"}"
> JSON.parse(json, json_deserialize_helper)
Object {test: Thu Sep 26 2013 05:05:26 GMT+0200 (CEST)}
想必您将这些日期序列化以将其存储在localStorage中。在这种情况下,你可以通过使用像rhaboo这样的包装库来避免像这样或类似的仇恨。 – 2015-04-21 05:11:22