Require or disallow an empty line between class members (lines-between-class-members
)
This rule improves readability by enforcing lines between class members. It will not check empty lines before the first member and after the last member. This rule require or disallow an empty line between class members.
Rule Details
This rule extends the base eslint/lines-between-class-members
rule.
It adds support for ignoring overload methods in a class.
See the ESLint documentation for more details on the lines-between-class-members
rule.
Rule Changes
{
// note you must disable the base rule as it can report incorrect errors
"lines-between-class-members": "off",
"@typescript-eslint/lines-between-class-members": ["error"]
}
In addition to the options supported by the lines-between-class-members
rule in ESLint core, the rule adds the following options:
Options
This rule has a string option and an object option.
Object option:
"exceptAfterOverload": true
(default) - Skip checking empty lines after overload class members"exceptAfterOverload": false
- do not skip checking empty lines after overload class members
exceptAfterOverload: true
Examples of correct code for the { "exceptAfterOverload": true }
option:
/*eslint @typescript-eslint/lines-between-class-members: ["error", "always", { "exceptAfterOverload": true }]*/
class foo {
bar(a: string): void;
bar(a: string, b: string): void;
bar(a: string, b: string) {}
baz() {}
qux() {}
}
exceptAfterOverload: false
Examples of correct code for the { "exceptAfterOverload": false }
option:
/*eslint @typescript-eslint/lines-between-class-members: ["error", "always", { "exceptAfterOverload": false }]*/
class foo {
bar(a: string): void;
bar(a: string, b: string): void;
bar(a: string, b: string) {}
baz() {}
qux() {}
}
Attributes
- โ Recommended
- ๐ง Fixable
- ๐ญ Requires type information