noInnerDeclarations
Diagnostic Category: lint/correctness/noInnerDeclarations
Since: v1.0.0
Sources:
- Same as:
no-inner-declarations
Description
Section titled DescriptionDisallow function
and var
declarations that are accessible outside their block.
A var
is accessible in the whole body of the nearest root (function, module, script, static block).
To avoid confusion, they should be declared to the nearest root.
Prior to ES2015, function
declarations were only allowed in the nearest root,
though parsers sometimes erroneously accept them elsewhere.
In ES2015, inside an ES module, a function
declaration is always block-scoped.
Note that const
and let
declarations are block-scoped,
and therefore they are not affected by this rule.
Moreover, function
declarations in nested blocks are allowed inside ES modules.
Examples
Section titled ExamplesInvalid
Section titled Invalidcode-block.cjs:2:5 lint/correctness/noInnerDeclarations ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
✖ This function should be declared at the root of the script.
1 │ if (test) {
> 2 │ function f() {}
│ ^^^^^^^^^^^^^^^
3 │ }
4 │
ℹ The function is accessible in the whole body of the script.
To avoid confusion, it should be declared at the root of the script.
code-block.js:2:5 lint/correctness/noInnerDeclarations ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
✖ This var should be declared at the root of the module.
1 │ if (test) {
> 2 │ var x = 1;
│ ^^^^^^^^^
3 │ }
4 │
ℹ The var is accessible in the whole body of the module.
To avoid confusion, it should be declared at the root of the module.
code-block.cjs:3:9 lint/correctness/noInnerDeclarations ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
✖ This function should be declared at the root of the enclosing function.
1 │ function f() {
2 │ if (test) {
> 3 │ function g() {}
│ ^^^^^^^^^^^^^^^
4 │ }
5 │ }
ℹ The function is accessible in the whole body of the enclosing function.
To avoid confusion, it should be declared at the root of the enclosing function.
code-block.js:3:9 lint/correctness/noInnerDeclarations ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
✖ This var should be declared at the root of the enclosing function.
1 │ function f() {
2 │ if (test) {
> 3 │ var x = 1;
│ ^^^^^^^^^
4 │ }
5 │ }
ℹ The var is accessible in the whole body of the enclosing function.
To avoid confusion, it should be declared at the root of the enclosing function.