版本

no-confusing-arrow

禁止箭头函数在可能与比较运算符混淆的地方使用

🔧 可修复

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

重要提示

此规则在 ESLint v8.53.0 中已弃用。请使用 @stylistic/eslint-plugin-js 中的相应规则

了解更多

箭头函数 (=>) 在语法上与某些比较运算符 (>, <, <=, 和 >=) 相似。此规则警告不要在可能与比较运算符混淆的地方使用箭头函数语法。

这是一个 => 的用法可能令人困惑的例子

// The intent is not clear
var x = a => 1 ? 2 : 3;
// Did the author mean this
var x = function (a) {
    return 1 ? 2 : 3;
};
// Or this
var x = a <= 1 ? 2 : 3;

规则详情

此规则的错误代码示例

在 Playground 中打开
/*eslint no-confusing-arrow: "error"*/

var x = a => 1 ? 2 : 3;
var x = (a) => 1 ? 2 : 3;

此规则的正确代码示例

在 Playground 中打开
/*eslint no-confusing-arrow: "error"*/

var x = a => (1 ? 2 : 3);
var x = (a) => (1 ? 2 : 3);
var x = (a) => {
    return 1 ? 2 : 3;
};
var x = a => { return 1 ? 2 : 3; };

选项

此规则接受两个选项参数,默认值如下

{
    "rules": {
        "no-confusing-arrow": [
            "error",
            { "allowParens": true, "onlyOneSimpleParam": false }
        ]
    }
}

allowParens 是一个布尔值设置,可以是 true(默认)或 false

  1. true 放宽了规则,并接受括号作为有效的“防止混淆”语法。
  2. false 即使表达式包含在括号中也会发出警告

此规则的 {"allowParens": false} 选项的错误代码示例

在 Playground 中打开
/*eslint no-confusing-arrow: ["error", {"allowParens": false}]*/

var x = a => (1 ? 2 : 3);
var x = (a) => (1 ? 2 : 3);

onlyOneSimpleParam 是一个布尔值设置,可以是 truefalse(默认)

  1. true 放宽了规则,如果箭头函数有 0 个或多于 1 个参数,或者参数不是标识符,则不会报告错误。
  2. false 无论参数如何都会发出警告。

此规则的 {"onlyOneSimpleParam": true} 选项的正确代码示例

在 Playground 中打开
/*eslint no-confusing-arrow: ["error", {"onlyOneSimpleParam": true}]*/

() => 1 ? 2 : 3;
(a, b) => 1 ? 2 : 3;
(a = b) => 1 ? 2 : 3;
({ a }) => 1 ? 2 : 3;
([a]) => 1 ? 2 : 3;
(...a) => 1 ? 2 : 3;

版本

此规则在 ESLint v2.0.0-alpha-2 中引入。

资源

更改语言