# no-else-return

if 语句中的 return 语句之后禁止 else

一些该规则报告的问题可以通过 --fix 命令行选项 自动修复

如果 if 块包含 return 语句,则 else 块变得不必要。它的内容可以放在块之外。

function foo() {
    if (x) {
        return y;
    } else {
        return z;
    }
}

# 规则详情

此规则旨在突出显示包含 return 语句的 if 之后的不必要的代码块。因此,它会在遇到 if 链后的 else 时发出警告,所有这些 if 都包含 return 语句。

# 选项

此规则有一个对象选项:

  • allowElseIf: true(默认)在返回后允许 else if
  • 返回后 allowElseIf: false 不允许 else if

# allowElseIf: true

此规则的错误代码示例:

/*eslint no-else-return: "error"*/

function foo() {
    if (x) {
        return y;
    } else {
        return z;
    }
}

function foo() {
    if (x) {
        return y;
    } else if (z) {
        return w;
    } else {
        return t;
    }
}

function foo() {
    if (x) {
        return y;
    } else {
        var t = "foo";
    }

    return t;
}

function foo() {
    if (error) {
        return 'It failed';
    } else {
        if (loading) {
            return "It's still loading";
        }
    }
}

// Two warnings for nested occurrences
function foo() {
    if (x) {
        if (y) {
            return y;
        } else {
            return x;
        }
    } else {
        return z;
    }
}

此规则的正确代码示例:

/*eslint no-else-return: "error"*/

function foo() {
    if (x) {
        return y;
    }

    return z;
}

function foo() {
    if (x) {
        return y;
    } else if (z) {
        var t = "foo";
    } else {
        return w;
    }
}

function foo() {
    if (x) {
        if (z) {
            return y;
        }
    } else {
        return z;
    }
}

function foo() {
    if (error) {
        return 'It failed';
    } else if (loading) {
        return "It's still loading";
    }
}

# allowElseIf: false

此规则的错误代码示例:

/*eslint no-else-return: ["error", {allowElseIf: false}]*/

function foo() {
    if (error) {
        return 'It failed';
    } else if (loading) {
        return "It's still loading";
    }
}

此规则的正确代码示例:

/*eslint no-else-return: ["error", {allowElseIf: false}]*/

function foo() {
    if (error) {
        return 'It failed';
    }

    if (loading) {
        return "It's still loading";
    }
}
Last Updated: 5/13/2023, 8:55:38 PM