Sha256: 17aaf93a0609d11f34e55d3c3f6be3b9f5b5e67038bf39fbbe7f7214ad343111

Contents?: true

Size: 1.79 KB

Versions: 49

Compression:

Stored size: 1.79 KB

Contents

# import/max-dependencies

<!-- end auto-generated rule header -->

Forbid modules to have too many dependencies (`import` or `require` statements).

This is a useful rule because a module with too many dependencies is a code smell, and usually indicates the module is doing too much and/or should be broken up into smaller modules.

Importing multiple named exports from a single module will only count once (e.g. `import {x, y, z} from './foo'` will only count as a single dependency).

## Options

This rule has the following options, with these defaults:

```js
"import/max-dependencies": ["error", {
  "max": 10,
  "ignoreTypeImports": false,
}]
```

### `max`

This option sets the maximum number of dependencies allowed. Anything over will trigger the rule. **Default is 10** if the rule is enabled and no `max` is specified.

Given a max value of `{"max": 2}`:

### Fail

```js
import a from './a'; // 1
const b = require('./b'); // 2
import c from './c'; // 3 - exceeds max!
```

### Pass

```js
import a from './a'; // 1
const anotherA = require('./a'); // still 1
import {x, y, z} from './foo'; // 2
```

### `ignoreTypeImports`

Ignores `type` imports. Type imports are a feature released in TypeScript 3.8, you can [read more here](https://www.typescriptlang.org/docs/handbook/release-notes/typescript-3-8.html#type-only-imports-and-export). Defaults to `false`.

Given `{"max": 2, "ignoreTypeImports": true}`:

<!-- markdownlint-disable-next-line MD024 -- duplicate header -->
### Fail

```ts
import a from './a';
import b from './b';
import c from './c';
```

<!-- markdownlint-disable-next-line MD024 -- duplicate header -->
### Pass

```ts
import a from './a';
import b from './b';
import type c from './c'; // Doesn't count against max
```

## When Not To Use It

If you don't care how many dependencies a module has.

Version data entries

49 entries across 49 versions & 1 rubygems

Version Path
immosquare-cleaner-0.1.60 node_modules/eslint-plugin-import/docs/rules/max-dependencies.md
immosquare-cleaner-0.1.59 node_modules/eslint-plugin-import/docs/rules/max-dependencies.md
immosquare-cleaner-0.1.58 node_modules/eslint-plugin-import/docs/rules/max-dependencies.md
immosquare-cleaner-0.1.57 node_modules/eslint-plugin-import/docs/rules/max-dependencies.md
immosquare-cleaner-0.1.56 node_modules/eslint-plugin-import/docs/rules/max-dependencies.md
immosquare-cleaner-0.1.55 node_modules/eslint-plugin-import/docs/rules/max-dependencies.md
immosquare-cleaner-0.1.54 node_modules/eslint-plugin-import/docs/rules/max-dependencies.md
immosquare-cleaner-0.1.53 node_modules/eslint-plugin-import/docs/rules/max-dependencies.md
immosquare-cleaner-0.1.52 node_modules/eslint-plugin-import/docs/rules/max-dependencies.md
immosquare-cleaner-0.1.51 node_modules/eslint-plugin-import/docs/rules/max-dependencies.md
immosquare-cleaner-0.1.50 node_modules/eslint-plugin-import/docs/rules/max-dependencies.md
immosquare-cleaner-0.1.49 node_modules/eslint-plugin-import/docs/rules/max-dependencies.md
immosquare-cleaner-0.1.48 node_modules/eslint-plugin-import/docs/rules/max-dependencies.md
immosquare-cleaner-0.1.47 node_modules/eslint-plugin-import/docs/rules/max-dependencies.md
immosquare-cleaner-0.1.46 node_modules/eslint-plugin-import/docs/rules/max-dependencies.md
immosquare-cleaner-0.1.45 node_modules/eslint-plugin-import/docs/rules/max-dependencies.md
immosquare-cleaner-0.1.44 node_modules/eslint-plugin-import/docs/rules/max-dependencies.md
immosquare-cleaner-0.1.43 node_modules/eslint-plugin-import/docs/rules/max-dependencies.md
immosquare-cleaner-0.1.42 node_modules/eslint-plugin-import/docs/rules/max-dependencies.md
immosquare-cleaner-0.1.41 node_modules/eslint-plugin-import/docs/rules/max-dependencies.md