no-else-return
禁止在 `if` 语句中 `return` 语句后的 `else` 块
🔧 可修复
此规则报告的某些问题可以通过 `--fix` 命令行 选项自动修复
如果 `if` 块包含 `return` 语句,则 `else` 块变得多余。其内容可以放置在块之外。
function foo() {
if (x) {
return y;
} else {
return z;
}
}
规则详情
此规则旨在突出显示 `if` 之后包含 `return` 语句的代码块。因此,当它遇到 `if` 链后面的 `else` 时,会发出警告,所有这些 `if` 都包含 `return` 语句。
选项
此规则有一个对象选项
allowElseIf: true
(默认) 允许 `return` 后的 `else if` 块allowElseIf: false
不允许 `return` 后的 `else if` 块
allowElseIf: true
此规则的 **不正确** 代码示例
在游乐场中打开
/*eslint no-else-return: "error"*/
function foo1() {
if (x) {
return y;
} else
}
function foo2() {
if (x) {
return y;
} else if (z) {
return w;
} else
}
function foo3() {
if (x) {
return y;
} else
return t;
}
function foo4() {
if (error) {
return 'It failed';
} else
}
// Two warnings for nested occurrences
function foo5() {
if (x) {
if (y) {
return y;
} else
} else
}
此规则的 **正确** 代码示例
在游乐场中打开
/*eslint no-else-return: "error"*/
function foo1() {
if (x) {
return y;
}
return z;
}
function foo2() {
if (x) {
return y;
} else if (z) {
var t = "foo";
} else {
return w;
}
}
function foo3() {
if (x) {
if (z) {
return y;
}
} else {
return z;
}
}
function foo4() {
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
}
此规则的 **正确** 代码示例
在游乐场中打开
/*eslint no-else-return: ["error", {allowElseIf: false}]*/
function foo() {
if (error) {
return 'It failed';
}
if (loading) {
return "It's still loading";
}
}
版本
此规则是在 ESLint v0.0.9 中引入的。