# 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";
}
}
← no-div-regex no-empty →