Oto coś naprawdę schludnego i prostego (przynajmniej tak mi się wydaje :)) i nie wymaga manipulacji datą w celu sklonowania lub przeładowania jakichkolwiek natywnych funkcji przeglądarki, takich jak toJSON (odniesienie: How to JSON stringify a javascript Date and keep timezone , court's Shawson)
Przekaż funkcję zamiennika do JSON.stringify, która ciągnie rzeczy do zawartości twojego serca !!! W ten sposób nie musisz robić różnic godzinowych i minutowych ani żadnych innych manipulacji.
Umieściłem w console.logs, aby zobaczyć wyniki pośrednie, aby było jasne, co się dzieje i jak działa rekurencja. To ujawnia coś godnego uwagi: parametr wartości zamiennika jest już przekonwertowany na format daty ISO :). Użyj tego [klawisza], aby pracować z oryginalnymi danymi.
var replacer = function(key, value)
{
var returnVal = value;
if(this[key] instanceof Date)
{
console.log("replacer called with key - ", key, " value - ", value, this[key]);
returnVal = this[key].toString();
/* Above line does not strictly speaking clone the date as in the cloned object
* it is a string in same format as the original but not a Date object. I tried
* multiple things but was unable to cause a Date object being created in the
* clone.
* Please Heeeeelp someone here!
returnVal = new Date(JSON.parse(JSON.stringify(this[key]))); //OR
returnVal = new Date(this[key]); //OR
returnVal = this[key]; //careful, returning original obj so may have potential side effect
*/
}
console.log("returning value: ", returnVal);
/* if undefined is returned, the key is not at all added to the new object(i.e. clone),
* so return null. null !== undefined but both are falsy and can be used as such*/
return this[key] === undefined ? null : returnVal;
};
ab = {prop1: "p1", prop2: [1, "str2", {p1: "p1inner", p2: undefined, p3: null, p4date: new Date()}]};
var abstr = JSON.stringify(ab, replacer);
var abcloned = JSON.parse(abstr);
console.log("ab is: ", ab);
console.log("abcloned is: ", abcloned);
/* abcloned is:
* {
"prop1": "p1",
"prop2": [
1,
"str2",
{
"p1": "p1inner",
"p2": null,
"p3": null,
"p4date": "Tue Jun 11 2019 18:47:50 GMT+0530 (India Standard Time)"
}
]
}
Note p4date is string not Date object but format and timezone are completely preserved.
*/
2009-09-28T10:00:00Z
nie przedstawia tego samego momentu w czasie coMon Sep 28 10:00:00 UTC+0200 2009
. DataZ
według ISO 8601 oznacza UTC, a godzina 10 w UTC to inny moment w czasie do godziny 10 w +0200. To jedno, gdyby data była serializowana z odpowiednią strefą czasową, ale prosisz nas o pomoc w serializacji do reprezentacji, która jest jednoznacznie, obiektywnie błędna .