HTML: Markup language
CSS: Styling language
JavaScript: Scripting language
Web APIs: Programming interfaces
All web technology
Learn web development
Discover our tools
Get to know MDN better
Dieser Inhalt wurde automatisch aus dem Englischen übersetzt, und kann Fehler enthalten. Erfahre mehr über dieses Experiment.
View in English Always switch to English
Diese Funktion ist gut etabliert und funktioniert auf vielen Geräten und in vielen Browserversionen. Sie ist seit Juli 2015 browserübergreifend verfügbar.
* Einige Teile dieser Funktion werden möglicherweise unterschiedlich gut unterstützt.
Nachgestellte Kommas (manchmal auch "Schlusskommas" genannt) können nützlich sein, wenn Sie neue Elemente, Parameter oder Eigenschaften zu JavaScript-Code hinzufügen. Wenn Sie eine neue Eigenschaft hinzufügen möchten, können Sie eine neue Zeile einfügen, ohne die bisher letzte Zeile zu ändern, sofern diese bereits ein nachgestelltes Komma verwendet. Dies macht Versionskontroll-Diffs sauberer, und das Bearbeiten von Code kann weniger problematisch sein.
JavaScript erlaubt seit jeher nachgestellte Kommas in Array-Literalen. Nachgestellte Kommas sind jetzt auch in Objekt-Literalen, Funktionsparametern, benannten Importen, benannten Exporten und mehr erlaubt.
JSON hingegen verbietet alle nachgestellten Kommas.
JavaScript erlaubt nachgestellte Kommas überall dort, wo eine durch Kommas getrennte Liste von Werten akzeptiert wird und nach dem letzten Element weitere Werte erwartet werden können. Dies schließt ein:
In all diesen Fällen ist das nachgestellte Komma völlig optional und ändert die Semantik des Programms in keiner Weise.
Es ist besonders nützlich beim Hinzufügen, Entfernen oder Umordnen von Elementen in einer Liste, die sich über mehrere Zeilen erstreckt, da es die Anzahl der zu ändernden Zeilen reduziert, was sowohl beim Bearbeiten als auch beim Überprüfen des Diffs hilft.
[ "foo", + "baz", "bar", - "baz", ]
JavaScript ignoriert nachgestellte Kommas in Array-Literalen:
const arr = [ 1, 2, 3, ]; arr; // [1, 2, 3] arr.length; // 3
Wenn mehr als ein nachgestelltes Komma verwendet wird, entsteht eine Auslassung (oder Lücke). Ein Array mit Lücken wird als sparsame (ein dichtes Array hat keine Lücken) bezeichnet. Beim Durchlaufen von Arrays, zum Beispiel mit Array.prototype.forEach() oder Array.prototype.map(), werden Array-Lücken übersprungen. Sparse Arrays sind im Allgemeinen ungünstig, daher sollten Sie mehrere nachgestellte Kommas vermeiden.
Array.prototype.forEach()
Array.prototype.map()
const arr = [1, 2, 3, , ,]; arr.length; // 5
Nachgestellte Kommas in Objekt-Literalen sind ebenfalls legal:
const object = { foo: "bar", baz: "qwerty", age: 42, };
Nachgestellte Kommas sind auch in Funktionsparameterlisten erlaubt.
Die folgenden Funktionsdefinitionen sind legal und gleichwertig zueinander. Nachgestellte Kommas beeinflussen weder die length-Eigenschaft von Funktionsdeklarationen noch deren arguments-Objekt.
length
arguments
function f(p) {} function f(p,) {} (p) => {}; (p,) => {};
Das nachgestellte Komma funktioniert auch bei Methodendefinitionen für Klassen oder Objekte:
class C { one(a,) {} two(a, b,) {} } const obj = { one(a,) {}, two(a, b,) {}, };
Die folgenden Funktionsaufrufe sind legal und gleichwertig zueinander.
f(p); f(p,); Math.max(10, 20); Math.max(10, 20,);
Funktionsparameterdefinitionen oder Funktionsaufrufe, die nur ein Komma enthalten, werfen einen SyntaxError. Darüber hinaus sind beim Verwenden von Rest-Parametern nachgestellte Kommas nicht erlaubt:
SyntaxError
function f(,) {} // SyntaxError: missing formal parameter (,) => {}; // SyntaxError: expected expression, got ',' f(,) // SyntaxError: expected expression, got ',' function f(...p,) {} // SyntaxError: parameter after rest parameter (...p,) => {} // SyntaxError: expected closing parenthesis, got ','
Ein nachgestelltes Komma ist auch innerhalb eines Destrukturierungs-Musters erlaubt:
// array destructuring with trailing comma [a, b,] = [1, 2]; // object destructuring with trailing comma const o = { p: 42, q: true, }; const { p, q, } = o;
Jedoch ist ein nachgestelltes Komma nach dem Rest-Element, falls vorhanden, nicht erlaubt:
const [a, ...b,] = [1, 2, 3]; // SyntaxError: rest element may not have a trailing comma
Da JSON auf einem sehr eingeschränkten Subset der JavaScript-Syntax basiert, sind nachgestellte Kommas in JSON nicht erlaubt.
Beide Zeilen werfen einen SyntaxError:
JSON.parse("[1, 2, 3, 4, ]"); JSON.parse('{"foo" : 1, }'); // SyntaxError JSON.parse: unexpected character // at line 1 column 14 of the JSON data
Lassen Sie die nachgestellten Kommas weg, um das JSON korrekt zu parsen:
JSON.parse("[1, 2, 3, 4 ]"); JSON.parse('{"foo" : 1 }');
Nachgestellte Kommas sind in benannten Importen und benannten Exporten gültig.
import { A, B, C, } from "D"; import { X, Y, Z, } from "W"; import { A as B, C as D, E as F, } from "Z";
export { A, B, C, }; export { A, B, C, }; export { A as B, C as D, E as F, };
Nachgestellte Kommas sind nur in dynamischen Importen erlaubt, wenn der Laufzeit auch der zweite options-Parameter implementiert ist.
options
import("D",); import( "D", { with: { type: "json" } }, );
Hinweis: Das nachgestellte Komma in einem Quantifier ändert tatsächlich seine Semantik von "genau n" zu "mindestens n".
n
/x{2}/; // Exactly 2 occurrences of "x"; equivalent to /xx/ /x{2,}/; // At least 2 occurrences of "x"; equivalent to /xx+/ /x{2,4}/; // 2 to 4 occurrences of "x"; equivalent to /xxx?x?/
JavaScript aktivieren, um diese Browser-Kompatibilitätstabelle anzuzeigen.