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 = () => ;
使用 "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 = () => ;
let bar = () => ;
使用預設 "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 = () => ();
使用 { "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 = () => ;
let bar = (retv, name) => ;
使用 "never"
選項時,此規則的正確程式碼範例
在遊樂場中開啟
/*eslint arrow-body-style: ["error", "never"]*/
let foo = () => 0;
let bar = () => ({ foo: 0 });
版本
此規則在 ESLint v1.8.0 中引入。