eslint-plugin-typescript
Version:
TypeScript plugin for ESLint
35 lines (21 loc) • 1.25 kB
Markdown
# Disallow generic `Array` constructors (no-array-constructor)
Use of the `Array` constructor to construct a new array is generally discouraged in favor of array literal notation because of the single-argument pitfall and because the `Array` global may be redefined. Two exceptions are when the Array constructor is used to intentionally create sparse arrays of a specified size by giving the constructor a single numeric argument, or when using TypeScript type parameters to specify the type of the items of the array (`new Array<Foo>()`).
## Rule Details
This rule disallows `Array` constructors.
Examples of **incorrect** code for this rule:
```ts
/*eslint no-array-constructor: "error"*/
Array(0, 1, 2)
new Array(0, 1, 2)
```
Examples of **correct** code for this rule:
```ts
/*eslint no-array-constructor: "error"*/
Array<number>(0, 1, 2)
new Array<Foo>(x, y, z)
Array(500)
new Array(someOtherArray.length)
```
## When Not To Use It
This rule enforces a nearly universal stylistic concern. That being said, this rule may be disabled if the constructor style is preferred.
<sup>Taken with ❤️ [from ESLint core](https://github.com/eslint/eslint/blob/7685fed33b15763ee3cf7dbe1facfc5ba85173f3/docs/rules/no-array-constructor.md)</sup>