max-classes-per-file
Enforce a maximum number of classes per file
包含多个类的文件往往会导致代码库的可操作性降低 和结构不良的代码库。最佳做法是将每个文件 只限于一个功能。
规则细节
此规则规定,每个文件只能包含特定数量类,而不能有更多的。
使用此规则的错误示例:
                            
                                Open in Playground
                            
/*eslint max-classes-per-file: "error"*/
class Foo {}
class Bar {}
使用此规则的正确示例:
                            
                                Open in Playground
                            
/*eslint max-classes-per-file: "error"*/
class Foo {}
选项
这个规则可以用一个对象或一个数字来配置。
如果选项是一个对象,它可以包含以下一个或两个。
ignoreExpressions:一个布尔选项(默认为false),用于忽略类的表达。max:一个数字选项(默认为 1),用于指定类的最大数量。
例如:
{
    "max-classes-per-file": ["error", 1]
}
{
    "max-classes-per-file": [
        "error",
        { "ignoreExpressions": true, "max": 2 }
    ]
}
使用该规则与将 max 选项设置为 2 的正确示例:
                            
                                Open in Playground
                            
/* eslint max-classes-per-file: ["error", 2] */
class Foo {}
class Bar {}
使用此规则与将 ignoreExpressions 选项设置为 true 的正确示例:
                            
                                Open in Playground
                            
            /* eslint max-classes-per-file: ["error", { ignoreExpressions: true }] */
class VisitorFactory {
    forDescriptor(descriptor) {
        return class {
            visit(node) {
                return `Visiting ${descriptor}.`;
            }
        };
    }
}
Version
This rule was introduced in ESLint v5.0.0-alpha.3.