Skip to content

@stylistic/js/

new-parens

JavaScript allows the omission of parentheses when invoking a function via the new keyword and the constructor has no arguments. However, some coders believe that omitting the parentheses is inconsistent with the rest of the language and thus makes code less clear.

js
var person = new Person;

Rule Details

This rule can enforce or disallow parentheses when invoking a constructor with no arguments using the new keyword.

Options

This rule takes one option.

  • "always" enforces parenthesis after a new constructor with no arguments (default)
  • "never" enforces no parenthesis after a new constructor with no arguments

always

Examples of incorrect code for this rule with the "always" option:

js
/*eslint @stylistic/js/new-parens: "error"*/

var person = 
new Person
;
var person =
new (Person)
;
incorrect

Examples of correct code for this rule with the "always" option:

js
/*eslint @stylistic/js/new-parens: "error"*/

var person = new Person();
var person = new (Person)();
correct

never

Examples of incorrect code for this rule with the "never" option:

js
/*eslint @stylistic/js/new-parens: ["error", "never"]*/

var person = 
new Person()
;
var person =
new (Person)()
;
incorrect

Examples of correct code for this rule with the "never" option:

js
/*eslint @stylistic/js/new-parens: ["error", "never"]*/

var person = new Person;
var person = (new Person);
var person = new Person("Name");
correct

Released under the MIT License.