Sha256: 587d5b3ec9dc29a0caa4ac6a24be21d30bd27f3e687779db5e161bd1a29c4972

Contents?: true

Size: 1.4 KB

Versions: 52

Compression:

Stored size: 1.4 KB

Contents

# import/no-mutable-exports

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

Forbids the use of mutable exports with `var` or `let`.

## Rule Details

Valid:

```js
export const count = 1
export function getCount() {}
export class Counter {}
```

...whereas here exports will be reported:

```js
export let count = 2
export var count = 3

let count = 4
export { count } // reported here
```

## Functions/Classes

Note that exported function/class declaration identifiers may be reassigned,
but are not flagged by this rule at this time. They may be in the future, if a
reassignment is detected, i.e.

```js
// possible future behavior!
export class Counter {} // reported here: exported class is reassigned on line [x].
Counter = KitchenSink // not reported here unless you enable no-class-assign

// this pre-declaration reassignment is valid on account of function hoisting
getCount = function getDuke() {} // not reported here without no-func-assign
export function getCount() {} // reported here: exported function is reassigned on line [x].
```

To prevent general reassignment of these identifiers, exported or not, you may
want to enable the following core ESLint rules:

 - [no-func-assign]
 - [no-class-assign]

[no-func-assign]: https://eslint.org/docs/rules/no-func-assign
[no-class-assign]: https://eslint.org/docs/rules/no-class-assign

## When Not To Use It

If your environment correctly implements mutable export bindings.

Version data entries

52 entries across 52 versions & 2 rubygems

Version Path
rapid_stack-0.2.0 templates/frontend/node_modules/eslint-plugin-import/docs/rules/no-mutable-exports.md
rapid_stack-0.1.1 templates/FrontEnd/node_modules/eslint-plugin-import/docs/rules/no-mutable-exports.md
rapid_stack-0.1.0 templates/FrontEnd/node_modules/eslint-plugin-import/docs/rules/no-mutable-exports.md
immosquare-cleaner-0.1.60 node_modules/eslint-plugin-import/docs/rules/no-mutable-exports.md
immosquare-cleaner-0.1.59 node_modules/eslint-plugin-import/docs/rules/no-mutable-exports.md
immosquare-cleaner-0.1.58 node_modules/eslint-plugin-import/docs/rules/no-mutable-exports.md
immosquare-cleaner-0.1.57 node_modules/eslint-plugin-import/docs/rules/no-mutable-exports.md
immosquare-cleaner-0.1.56 node_modules/eslint-plugin-import/docs/rules/no-mutable-exports.md
immosquare-cleaner-0.1.55 node_modules/eslint-plugin-import/docs/rules/no-mutable-exports.md
immosquare-cleaner-0.1.54 node_modules/eslint-plugin-import/docs/rules/no-mutable-exports.md
immosquare-cleaner-0.1.53 node_modules/eslint-plugin-import/docs/rules/no-mutable-exports.md
immosquare-cleaner-0.1.52 node_modules/eslint-plugin-import/docs/rules/no-mutable-exports.md
immosquare-cleaner-0.1.51 node_modules/eslint-plugin-import/docs/rules/no-mutable-exports.md
immosquare-cleaner-0.1.50 node_modules/eslint-plugin-import/docs/rules/no-mutable-exports.md
immosquare-cleaner-0.1.49 node_modules/eslint-plugin-import/docs/rules/no-mutable-exports.md
immosquare-cleaner-0.1.48 node_modules/eslint-plugin-import/docs/rules/no-mutable-exports.md
immosquare-cleaner-0.1.47 node_modules/eslint-plugin-import/docs/rules/no-mutable-exports.md
immosquare-cleaner-0.1.46 node_modules/eslint-plugin-import/docs/rules/no-mutable-exports.md
immosquare-cleaner-0.1.45 node_modules/eslint-plugin-import/docs/rules/no-mutable-exports.md
immosquare-cleaner-0.1.44 node_modules/eslint-plugin-import/docs/rules/no-mutable-exports.md