版本

复杂度

强制执行程序中允许的最大环路复杂度。

环路复杂度衡量程序源代码中线性独立路径的数量。此规则允许设置环路复杂度的阈值。

function a(x) {
    if (true) {
        return x; // 1st path
    } else if (false) {
        return x+1; // 2nd path
    } else {
        return 4; // 3rd path
    }
}

规则详情

此规则旨在通过限制程序中允许的环路复杂度的数量来降低代码复杂度。因此,当环路复杂度超过配置的阈值(默认值为 20)时,它会发出警告。

最大值为 2 时错误代码示例

在 Playground 中打开
/*eslint complexity: ["error", 2]*/

function a(x) {
    if (true) {
        return x;
    } else if (false) {
        return x+1;
    } else {
        return 4; // 3rd path
    }
}

function b() {
    foo ||= 1;
    bar &&= 1;
}

function c(a = {}) { // default parameter -> 2nd path
    const { b = 'default' } = a; // default value during destructuring -> 3rd path
}

function d(a) {
    return a?.b?.c; // optional chaining with two optional properties creates two additional branches
}

最大值为 2 时正确代码示例

在 Playground 中打开
/*eslint complexity: ["error", 2]*/

function a(x) {
    if (true) {
        return x;
    } else {
        return 4;
    }
}

function b() {
    foo ||= 1;
}

类字段初始化程序和类静态块是隐式函数。因此,它们的复杂度会为每个初始化程序和每个静态块分别计算,并且不会影响封闭代码的复杂度。

最大值为 2 时其他错误代码示例

在 Playground 中打开
/*eslint complexity: ["error", 2]*/

class C {
    x = a || b || c; // this initializer has complexity = 3
}

class D { // this static block has complexity = 3
    static {
        if (foo) {
            bar = baz || qux;
        }
    }
}

最大值为 2 时其他正确代码示例

在 Playground 中打开
/*eslint complexity: ["error", 2]*/

function foo() { // this function has complexity = 1
    class C {
        x = a + b; // this initializer has complexity = 1
        y = c || d; // this initializer has complexity = 2
        z = e && f; // this initializer has complexity = 2

        static p = g || h; // this initializer has complexity = 2
        static q = i ? j : k; // this initializer has complexity = 2

        static { // this static block has complexity = 2
            if (foo) {
                baz = bar;
            }
        }

        static { // this static block has complexity = 2
            qux = baz || quux;
        }
    }
}

选项

此规则具有数字或对象选项

  • "max"(默认值:20)强制执行最大复杂度

  • "variant": "classic" | "modified"(默认值:"classic")要使用的环路复杂度变体

max

使用 max 属性自定义阈值。

"complexity": ["error", { "max": 2 }]

已弃用:对象属性 maximum 已弃用。请改用属性 max

或使用简写语法

"complexity": ["error", 2]

variant

要使用的环路复杂度变体

  • "classic"(默认值) - 经典的麦凯布环路复杂度
  • "modified" - 修改后的环路复杂度

修改后的环路复杂度与经典的环路复杂度相同,但每个 switch 语句只会将复杂度值增加 1,无论它包含多少个 case 语句。

使用 { "max": 3, "variant": "modified" } 选项时,此规则的正确代码示例

在 Playground 中打开
/*eslint complexity: ["error", {"max": 3, "variant": "modified"}]*/

function a(x) {     // initial modified complexity is 1
    switch (x) {    // switch statement increases modified complexity by 1
        case 1:
            1;
            break;
        case 2:
            2;
            break;
        case 3:
            if (x === 'foo') {  // if block increases modified complexity by 1
                3;
            }
            break;
        default:
            4;
    }
}

上面函数的经典环路复杂度为 5,但修改后的环路复杂度仅为 3

何时不使用它

如果您无法确定代码的适当复杂度限制,那么最好禁用此规则。

版本

此规则在 ESLint v0.0.9 中引入。

进一步阅读

资源

更改语言