版本

arrow-body-style

要求在箭頭函式主體周圍使用大括號

🔧 可修正

此規則報告的一些問題可透過 --fix 命令列 選項自動修正

箭頭函式在其函式主體方面有兩種語法形式。它們可以用區塊主體(以大括號表示)() => { ... } 定義,或用單一運算式 () => ... 定義,其值會隱式傳回。

規則詳細資訊

此規則可以強制執行或禁止在箭頭函式主體周圍使用大括號。

選項

此規則採用一個或兩個選項。第一個是一個字串,可以是

  • "always" 強制在函式主體周圍使用大括號
  • "as-needed" 強制在可以省略大括號的地方不使用(預設)
  • "never" 強制在函式主體周圍不使用大括號(將箭頭函式限制為傳回運算式)

第二個選項是一個物件,當第一個選項為 "as-needed" 時,可以用於更精細的設定。目前,唯一可用的選項是 requireReturnForObjectLiteral,一個布林屬性。預設值為 false。如果設為 true,則要求物件文字使用大括號和明確的傳回。

"arrow-body-style": ["error", "always"]

always

使用 "always" 選項時,此規則的不正確程式碼範例

在遊樂場中開啟
/*eslint arrow-body-style: ["error", "always"]*/

let foo = () => 0;

使用 "always" 選項時,此規則的正確程式碼範例

在遊樂場中開啟
/*eslint arrow-body-style: ["error", "always"]*/

let foo = () => {
    return 0;
};
let bar = (retv, name) => {
    retv[name] = true;
    return retv;
};

as-needed

使用預設 "as-needed" 選項時,此規則的不正確程式碼範例

在遊樂場中開啟
/*eslint arrow-body-style: ["error", "as-needed"]*/

let foo = () => {
    return 0;
};
let bar = () => {
    return {
       bar: {
            foo: 1,
            bar: 2,
        }
    };
};

使用預設 "as-needed" 選項時,此規則的正確程式碼範例

在遊樂場中開啟
/*eslint arrow-body-style: ["error", "as-needed"]*/

let foo1 = () => 0;
let foo2 = (retv, name) => {
    retv[name] = true;
    return retv;
};
let foo3 = () => ({
    bar: {
        foo: 1,
        bar: 2,
    }
});
let foo4 = () => { bar(); };
let foo5 = () => {};
let foo6 = () => { /* do nothing */ };
let foo7 = () => {
    // do nothing.
};
let foo8 = () => ({ bar: 0 });

requireReturnForObjectLiteral

此選項僅適用於與 "as-needed" 選項結合使用時。

使用 { "requireReturnForObjectLiteral": true } 選項時,此規則的不正確程式碼範例

在遊樂場中開啟
/*eslint arrow-body-style: ["error", "as-needed", { "requireReturnForObjectLiteral": true }]*/

let foo = () => ({});
let bar = () => ({ bar: 0 });

使用 { "requireReturnForObjectLiteral": true } 選項時,此規則的正確程式碼範例

在遊樂場中開啟
/*eslint arrow-body-style: ["error", "as-needed", { "requireReturnForObjectLiteral": true }]*/

let foo = () => {};
let bar = () => { return { bar: 0 }; };

never

使用 "never" 選項時,此規則的不正確程式碼範例

在遊樂場中開啟
/*eslint arrow-body-style: ["error", "never"]*/

let foo = () => {
    return 0;
};
let bar = (retv, name) => {
    retv[name] = true;
    return retv;
};

使用 "never" 選項時,此規則的正確程式碼範例

在遊樂場中開啟
/*eslint arrow-body-style: ["error", "never"]*/

let foo = () => 0;
let bar = () => ({ foo: 0 });

版本

此規則在 ESLint v1.8.0 中引入。

資源

變更語言