Enforce consistent comma style
Some problems reported by this rule are automatically fixable by the --fix
command line option
The Comma Style rule enforces styles for comma-separated lists. There are two comma styles primarily used in JavaScript:
One of the justifications for using Comma First style is that it can help track missing and trailing commas. These are problematic because missing commas in variable declarations can lead to the leakage of global variables and trailing commas can lead to errors in older versions of IE.
This rule enforce consistent comma style in array literals, object literals, and variable declarations.
This rule does not apply in either of the following cases:
This rule has a string option:
"last"
(default) requires a comma after and on the same line as an array element, object property, or variable declaration"first"
requires a comma before and on the same line as an array element, object property, or variable declarationThis rule also accepts an additional exceptions
object:
"exceptions"
has properties whose names correspond to node types in the abstract syntax tree (AST) of JavaScript code:
"ArrayExpression": true
ignores comma style in array literals"ArrayPattern": true
ignores comma style in array patterns of destructuring"ArrowFunctionExpression": true
ignores comma style in the parameters of arrow function expressions"CallExpression": true
ignores comma style in the arguments of function calls"FunctionDeclaration": true
ignores comma style in the parameters of function declarations"FunctionExpression": true
ignores comma style in the parameters of function expressions"ImportDeclaration": true
ignores comma style in the specifiers of import declarations"ObjectExpression": true
ignores comma style in object literals"ObjectPattern": true
ignores comma style in object patterns of destructuring"VariableDeclaration": true
ignores comma style in variable declarations"NewExpression": true
ignores comma style in the parameters of constructor expressionsA way to determine the node types as defined by ESTree is to use AST Explorer with the espree parser.
Examples of incorrect code for this rule with the default "last"
option:
/*eslint comma-style: ["error", "last"]*/
var foo = 1
,
bar = 2;
var foo = 1
, bar = 2;
var foo = ["apples"
, "oranges"];
function bar() {
return {
"a": 1
,"b:": 2
};
}
Examples of correct code for this rule with the default "last"
option:
/*eslint comma-style: ["error", "last"]*/
var foo = 1, bar = 2;
var foo = 1,
bar = 2;
var foo = ["apples",
"oranges"];
function bar() {
return {
"a": 1,
"b:": 2
};
}
Examples of incorrect code for this rule with the "first"
option:
/*eslint comma-style: ["error", "first"]*/
var foo = 1,
bar = 2;
var foo = ["apples",
"oranges"];
function bar() {
return {
"a": 1,
"b:": 2
};
}
Examples of correct code for this rule with the "first"
option:
/*eslint comma-style: ["error", "first"]*/
var foo = 1, bar = 2;
var foo = 1
,bar = 2;
var foo = ["apples"
,"oranges"];
function bar() {
return {
"a": 1
,"b:": 2
};
}
An example use case is to enforce comma style only in var statements.
Examples of incorrect code for this rule with sample "first", { "exceptions": { … } }
options:
/*eslint comma-style: ["error", "first", { "exceptions": { "ArrayExpression": true, "ObjectExpression": true } }]*/
var o = {},
a = [];
Examples of correct code for this rule with sample "first", { "exceptions": { … } }
options:
/*eslint comma-style: ["error", "first", { "exceptions": { "ArrayExpression": true, "ObjectExpression": true } }]*/
var o = {fst:1,
snd: [1,
2]}
, a = [];
This rule can safely be turned off if your project does not care about enforcing a consistent comma style.
This rule was introduced in ESLint v0.9.0.
© OpenJS Foundation and other contributors
Licensed under the MIT License.
https://eslint.org/docs/latest/rules/comma-style