JSON.stringify()
Baseline Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since July 2015.
Die JSON.stringify()
statische Methode wandelt einen JavaScript-Wert in einen JSON-String um. Optional können Werte ersetzt werden, falls eine Ersetzungsfunktion angegeben ist, oder nur die angegebenen Eigenschaften eingeschlossen werden, wenn ein Ersetzungsarray angegeben ist.
Probieren Sie es aus
console.log(JSON.stringify({ x: 5, y: 6 }));
// Expected output: '{"x":5,"y":6}'
console.log(
JSON.stringify([new Number(3), new String("false"), new Boolean(false)]),
);
// Expected output: '[3,"false",false]'
console.log(JSON.stringify({ x: [10, undefined, function () {}, Symbol("")] }));
// Expected output: '{"x":[10,null,null,null]}'
console.log(JSON.stringify(new Date(2006, 0, 2, 15, 4, 5)));
// Expected output: '"2006-01-02T15:04:05.000Z"'
Syntax
JSON.stringify(value)
JSON.stringify(value, replacer)
JSON.stringify(value, replacer, space)
Parameter
value
-
Der Wert, der in einen JSON-String konvertiert werden soll.
replacer
Optional-
Eine Funktion, die das Verhalten des Stringifizierungsprozesses ändert, oder ein Array von Zeichenfolgen und Zahlen, das die Eigenschaften von
value
angibt, die in die Ausgabe eingeschlossen werden sollen. Wennreplacer
ein Array ist, werden alle Elemente in diesem Array, die keine Zeichenfolgen oder Zahlen sind (entweder primitives oder Wrapper-Objekte), einschließlichSymbol
-Werten, vollständig ignoriert. Wennreplacer
etwas anderes als eine Funktion oder ein Array ist (z. B.null
oder nicht angegeben), werden alle zeichenfolgenindizierten Eigenschaften des Objekts im resultierenden JSON-String eingeschlossen. space
Optional-
Eine Zeichenfolge oder Zahl, die zur Einfügung von Leerzeichen (einschließlich Einrückung, Zeilenumbruchzeichen usw.) in den Ausgabe-JSON-String für bessere Lesbarkeit verwendet wird.
Wenn dies eine Zahl ist, gibt sie die Anzahl der Leerzeichen an, die als Einrückung verwendet werden sollen, wobei sie auf 10 begrenzt ist (d.h. jede Zahl größer als
10
wird behandelt, als wäre sie10
). Werte kleiner als 1 bedeuten, dass keine Leerzeichen verwendet werden sollen.Wenn dies eine Zeichenfolge ist, wird die Zeichenfolge (oder die ersten 10 Zeichen der Zeichenfolge, wenn sie länger ist) vor jedem verschachtelten Objekt oder Array eingefügt.
Wenn
space
etwas anderes als eine Zeichenfolge oder Zahl ist (entweder ein primitives oder ein Wrapper-Objekt) - zum Beispielnull
oder nicht angegeben - werden keine Leerzeichen verwendet.
Rückgabewert
Ein JSON-String, der den angegebenen Wert darstellt, oder undefined.
Ausnahmen
Beschreibung
JSON.stringify()
wandelt einen Wert in die JSON-Notation um, die den Wert darstellt. Werte werden folgendermaßen stringifiziert:
-
Boolean
,Number
,String
undBigInt
(erhältlich überObject()
) Objekte werden während der Stringifizierung in die entsprechenden primitiven Werte umgewandelt, gemäß der traditionellen Konversionssemantik.Symbol
-Objekte (erhältlich überObject()
) werden als normale Objekte behandelt. -
Der Versuch,
BigInt
-Werte zu serialisieren, wird scheitern. Hat der BigInt jedoch einetoJSON()
-Methode (durch Monkey Patching:BigInt.prototype.toJSON = ...
), kann diese Methode das Serialisierungsergebnis liefern. Diese Einschränkung stellt sicher, dass immer ein korrektes Serialisierungsverhalten (und sehr wahrscheinlich auch das entsprechende Deserialisierungsverhalten) explizit vom Benutzer bereitgestellt wird. -
undefined
,Function
undSymbol
-Werte sind keine gültigen JSON-Werte. Sollte ein solcher Wert während der Umwandlung angetroffen werden, wird er entweder weggelassen (wenn im Objekt gefunden) oder innull
geändert (wenn im Array gefunden).JSON.stringify()
kannundefined
zurückgeben, wenn "pure" Werte wieJSON.stringify(() => {})
oderJSON.stringify(undefined)
übergeben werden. -
Die Zahlen
Infinity
undNaN
, sowie der Wertnull
, werden alle alsnull
betrachtet. (Im Gegensatz zu den Werten des vorherigen Punktes, würden diese jedoch nie weggelassen.) -
Arrays werden als Arrays serialisiert (eingeschlossen in eckige Klammern). Nur Array-Indizes zwischen 0 und
length - 1
(einschließlich) werden serialisiert; andere Eigenschaften werden ignoriert. -
Das spezielle rohe JSON-Objekt, das mit
JSON.rawJSON()
erstellt wurde, wird als der rohe JSON-Text serialisiert, den es enthält (durch Zugriff auf seinerawJSON
-Eigenschaft). -
Für andere Objekte:
-
Alle
Symbol
-indizierten Eigenschaften werden vollständig ignoriert, selbst wenn derreplacer
-Parameter verwendet wird. -
Hat der Wert eine
toJSON()
-Methode, ist es verantwortlich, welche Daten serialisiert werden. Anstatt das Objekt zu serialisieren, wird der Wert, der von dertoJSON()
-Methode zurückgegeben wird, serialisiert.JSON.stringify()
rufttoJSON
mit einem Parameterkey
auf, der den gleichen semantischen Wert wie derkey
-Parameter derreplacer
-Funktion hat:- Wenn dieses Objekt ein Eigenschaftswert ist, der Eigenschaftenname
- Wenn es in einem Array ist, der Index im Array, als Zeichenfolge
- Wenn
JSON.stringify()
direkt auf dieses Objekt angewendet wird, eine leere Zeichenfolge
Alle
Temporal
-Objekte implementieren dietoJSON()
-Methode, die eine Zeichenfolge (gleich dem Aufruf vontoString()
) zurückgibt. Daher werden sie als Zeichenfolgen serialisiert. Ebenso implementierenDate
-ObjektetoJSON()
, das dasselbe wietoISOString()
zurückgibt. -
Es werden nur enumerable own properties besucht. Dies bedeutet, dass
Map
,Set
usw. zu"{}"
werden. Sie können denreplacer
-Parameter verwenden, um sie in etwas Nützlicheres zu serialisieren.Eigenschaften werden mit dem gleichen Algorithmus wie
Object.keys()
besucht, der eine wohldefinierte Reihenfolge hat und implementierungsübergreifend stabil ist. Zum Beispiel wirdJSON.stringify
auf demselben Objekt immer denselben String produzieren, undJSON.parse(JSON.stringify(obj))
würde ein Objekt mit derselben Schlüsselreihenfolge wie das Original produzieren (vorausgesetzt, das Objekt ist vollständig JSON-serialisierbar).
-
Der replacer-Parameter
Der replacer
-Parameter kann entweder eine Funktion oder ein Array sein.
Als Array geben seine Elemente die Namen der Eigenschaften im Objekt an, die in den resultierenden JSON-String aufgenommen werden sollen. Nur Zeichenketten- und Zahlenwerte werden berücksichtigt; Symbolschlüssel werden ignoriert.
Als Funktion nimmt es zwei Parameter: den key
und den value
, der stringifiziert werden soll. Das Objekt, in dem der Schlüssel gefunden wurde, wird als this
-Kontext der replacer
-Funktion bereitgestellt.
Die replacer
-Funktion wird auch für das initial stringifizierte Objekt aufgerufen, in welchem Fall der key
eine leere Zeichenfolge (""
) ist. Anschließend wird sie für jede Eigenschaft des Objekts oder Arrays aufgerufen, das stringifiziert wird. Array-Indizes werden in ihrer Zeichenform als key
bereitgestellt. Der aktuelle Eigenschaftswert wird durch den Rückgabewert der replacer
-Funktion für die Stringifizierung ersetzt. Das bedeutet:
- Wenn Sie eine Zahl, Zeichenkette, boolean oder
null
zurückgeben, wird dieser Wert direkt serialisiert und als Eigenschaftswert verwendet. (Die Rückgabe eines BigInt löst ebenfalls einen Fehler aus.) - Wenn Sie eine
Function
,Symbol
oderundefined
zurückgeben, wird die Eigenschaft in der Ausgabe nicht enthalten. - Wenn Sie ein anderes Objekt zurückgeben, wird das Objekt rekursiv stringifiziert, indem die
replacer
-Funktion auf jede Eigenschaft angewendet wird.
Hinweis:
Beim Analysieren von JSON, das mit replacer
-Funktionen erzeugt wurde, möchten Sie möglicherweise den reviver
-Parameter verwenden, um die Umkehrung der Operation durchzuführen.
Typischerweise würde sich der Index von Array-Elementen niemals verschieben (selbst wenn das Element ein ungültiger Wert wie eine Funktion ist, wird es null
statt ausgelassen). Die Verwendung der replacer
-Funktion erlaubt die Kontrolle der Reihenfolge der Array-Elemente, indem ein unterschiedliches Array zurückgegeben wird.
Der space-Parameter
Der space
-Parameter kann verwendet werden, um den Abstand im finalen String zu kontrollieren.
- Wenn es eine Zahl ist, werden aufeinanderfolgende Ebenen der Stringifizierung jeweils durch diese Anzahl an Leerzeichen eingerückt.
- Wenn es eine Zeichenkette ist, werden aufeinanderfolgende Ebenen durch diese Zeichenkette eingerückt.
Jede Ebene der Einrückung wird niemals länger als 10 sein. Zahlenwerte von space
werden auf 10 begrenzt, und Zeichenfolgenwerte werden auf 10 Zeichen gekürzt.
Beispiele
Verwendung von JSON.stringify
JSON.stringify({}); // '{}'
JSON.stringify(true); // 'true'
JSON.stringify("foo"); // '"foo"'
JSON.stringify([1, "false", false]); // '[1,"false",false]'
JSON.stringify([NaN, null, Infinity]); // '[null,null,null]'
JSON.stringify({ x: 5 }); // '{"x":5}'
JSON.stringify(new Date(1906, 0, 2, 15, 4, 5));
// '"1906-01-02T15:04:05.000Z"'
JSON.stringify({ x: 5, y: 6 });
// '{"x":5,"y":6}'
JSON.stringify([new Number(3), new String("false"), new Boolean(false)]);
// '[3,"false",false]'
// String-keyed array elements are not enumerable and make no sense in JSON
const a = ["foo", "bar"];
a["baz"] = "quux"; // a: [ 0: 'foo', 1: 'bar', baz: 'quux' ]
JSON.stringify(a);
// '["foo","bar"]'
JSON.stringify({ x: [10, undefined, function () {}, Symbol("")] });
// '{"x":[10,null,null,null]}'
// Standard data structures
JSON.stringify([
new Set([1]),
new Map([[1, 2]]),
new WeakSet([{ a: 1 }]),
new WeakMap([[{ a: 1 }, 2]]),
]);
// '[{},{},{},{}]'
// TypedArray
JSON.stringify([new Int8Array([1]), new Int16Array([1]), new Int32Array([1])]);
// '[{"0":1},{"0":1},{"0":1}]'
JSON.stringify([
new Uint8Array([1]),
new Uint8ClampedArray([1]),
new Uint16Array([1]),
new Uint32Array([1]),
]);
// '[{"0":1},{"0":1},{"0":1},{"0":1}]'
JSON.stringify([new Float32Array([1]), new Float64Array([1])]);
// '[{"0":1},{"0":1}]'
// toJSON()
JSON.stringify({
x: 5,
y: 6,
toJSON() {
return this.x + this.y;
},
});
// '11'
// Symbols:
JSON.stringify({ x: undefined, y: Object, z: Symbol("") });
// '{}'
JSON.stringify({ [Symbol("foo")]: "foo" });
// '{}'
JSON.stringify({ [Symbol.for("foo")]: "foo" }, [Symbol.for("foo")]);
// '{}'
JSON.stringify({ [Symbol.for("foo")]: "foo" }, (k, v) => {
if (typeof k === "symbol") {
return "a symbol";
}
});
// undefined
// Non-enumerable properties:
JSON.stringify(
Object.create(null, {
x: { value: "x", enumerable: false },
y: { value: "y", enumerable: true },
}),
);
// '{"y":"y"}'
// BigInt values throw
JSON.stringify({ x: 2n });
// TypeError: BigInt value can't be serialized in JSON
Verwendung einer Funktion als replacer
function replacer(key, value) {
// Filtering out properties
if (typeof value === "string") {
return undefined;
}
return value;
}
const foo = {
foundation: "Mozilla",
model: "box",
week: 45,
transport: "car",
month: 7,
};
JSON.stringify(foo, replacer);
// '{"week":45,"month":7}'
Wenn Sie möchten, dass der replacer
ein initiales Objekt von einem Schlüssel mit einer leeren Zeichenkettens-Eigenschaft unterscheidet (da beide den leeren String als Schlüssel und möglicherweise ein Objekt als Wert geben würden), müssen Sie die Iterationsanzahl verfolgen (wenn sie über der ersten Iteration liegt, handelt es sich um einen echten leeren Zeichenfolgeschlüssel).
function makeReplacer() {
let isInitial = true;
return (key, value) => {
if (isInitial) {
isInitial = false;
return value;
}
if (key === "") {
// Omit all properties with name "" (except the initial object)
return undefined;
}
return value;
};
}
const replacer = makeReplacer();
console.log(JSON.stringify({ "": 1, b: 2 }, replacer)); // "{"b":2}"
Verwendung eines Arrays als replacer
const foo = {
foundation: "Mozilla",
model: "box",
week: 45,
transport: "car",
month: 7,
};
JSON.stringify(foo, ["week", "month"]);
// '{"week":45,"month":7}', only keep "week" and "month" properties
Verwendung des space-Parameters
Indizieren Sie die Ausgabe mit einem Leerzeichen:
console.log(JSON.stringify({ a: 2 }, null, " "));
/*
{
"a": 2
}
*/
Durch die Verwendung eines Tab-Zeichens wird das Erscheinungsbild eines Standard-Pretty-Prints imitiert:
console.log(JSON.stringify({ uno: 1, dos: 2 }, null, "\t"));
/*
{
"uno": 1,
"dos": 2
}
*/
toJSON()-Verhalten
Das Definieren von toJSON()
für ein Objekt ermöglicht das Überschreiben seines Serialisierungsverhaltens.
const obj = {
data: "data",
toJSON(key) {
return key ? `Now I am a nested object under key '${key}'` : this;
},
};
JSON.stringify(obj);
// '{"data":"data"}'
JSON.stringify({ obj });
// '{"obj":"Now I am a nested object under key 'obj'"}'
JSON.stringify([obj]);
// '["Now I am a nested object under key '0'"]'
Problem bei der Serialisierung von zyklischen Referenzen
Da das JSON-Format keine Objektreferenzen unterstützt (obwohl ein IETF-Draft existiert), wird ein TypeError
ausgelöst, wenn man versucht, ein Objekt mit zyklischen Referenzen zu kodieren.
const circularReference = {};
circularReference.myself = circularReference;
// Serializing circular references throws "TypeError: cyclic object value"
JSON.stringify(circularReference);
Um zyklische Referenzen zu serialisieren, können Sie eine Bibliothek verwenden, die sie unterstützt (z. B. cycle.js von Douglas Crockford) oder selbst eine Lösung implementieren, die das Finden und Ersetzen (oder Entfernen) der zyklischen Referenzen durch serialisierbare Werte erfordert.
Wenn Sie JSON.stringify()
verwenden, um ein Objekt tiefgreifend zu kopieren, möchten Sie stattdessen möglicherweise structuredClone()
verwenden, das zyklische Referenzen unterstützt. JavaScript-Engine-APIs zur binären Serialisierung, wie v8.serialize()
, unterstützen ebenfalls zyklische Referenzen.
Verwendung von JSON.stringify() mit localStorage
In einem Fall, in dem Sie ein vom Benutzer erstelltes Objekt speichern und es auch nach dem Schließen des Browsers wiederherstellen möchten, ist das folgende Beispiel ein Modell für die Anwendbarkeit von JSON.stringify()
:
// Creating an example of JSON
const session = {
screens: [],
state: true,
};
session.screens.push({ name: "screenA", width: 450, height: 250 });
session.screens.push({ name: "screenB", width: 650, height: 350 });
session.screens.push({ name: "screenC", width: 750, height: 120 });
session.screens.push({ name: "screenD", width: 250, height: 60 });
session.screens.push({ name: "screenE", width: 390, height: 120 });
session.screens.push({ name: "screenF", width: 1240, height: 650 });
// Converting the JSON string with JSON.stringify()
// then saving with localStorage in the name of session
localStorage.setItem("session", JSON.stringify(session));
// Example of how to transform the String generated through
// JSON.stringify() and saved in localStorage in JSON object again
const restoredSession = JSON.parse(localStorage.getItem("session"));
// Now restoredSession variable contains the object that was saved
// in localStorage
console.log(restoredSession);
Well-formed JSON.stringify()
Engines, die die well-formed JSON.stringify-Spezifikation implementieren, werden einzelne Surrogate (jedes Codepunkt von U+D800 bis U+DFFF) mit Unicode-Escape-Sequenzen anstelle von wörtlichen Surrogaten stringifizieren. Vor dieser Änderung konnten solche Zeichenfolgen nicht in gültigem UTF-8 oder UTF-16 codiert werden:
JSON.stringify("\uD800"); // '"�"'
Mit dieser Änderung stellt JSON.stringify()
einzelne Surrogate mit JSON-Escape-Sequenzen dar, die in gültigem UTF-8 oder UTF-16 codiert werden können:
JSON.stringify("\uD800"); // '"\\ud800"'
Diese Änderung sollte rückwärtskompatibel sein, solange Sie das Ergebnis von JSON.stringify()
an APIs wie JSON.parse()
übergeben, die jeden gültigen JSON-Text akzeptieren, da sie Unicode-Escapes einzelner Surrogate als identisch mit den einzelnen Surrogaten selbst behandeln. Nur wenn Sie das Ergebnis von JSON.stringify()
direkt interpretieren, müssen Sie JSON.stringify()
s zwei mögliche Codierungen dieser Codepunkte sorgfältig handhaben.
Spezifikationen
Specification |
---|
ECMAScript® 2026 Language Specification # sec-json.stringify |