版本

no-func-assign

不允許重新指派 function 宣告

建議

設定檔中使用來自 @eslint/jsrecommended 設定會啟用此規則

JavaScript 函式可以寫成 FunctionDeclaration function foo() { ... } 或 FunctionExpression const foo = function() { ... };。雖然 JavaScript 直譯器可能會容忍它,但覆寫/重新指派寫成 FunctionDeclaration 的函式通常表示錯誤或問題。

function foo() {}
foo = bar;

規則詳情

此規則不允許重新指派 function 宣告。

此規則的不正確程式碼範例

在 Playground 中開啟
/*eslint no-func-assign: "error"*/

function foo() {}
foo = bar;

function baz() {
    baz = bar;
}

let a = function hello() {
  hello = 123;
};

此規則的不正確程式碼範例,與 JSHint 中對應的規則不同

在 Playground 中開啟
/*eslint no-func-assign: "error"*/

foo = bar;
function foo() {}

此規則的正確程式碼範例

在 Playground 中開啟
/*eslint no-func-assign: "error"*/

let foo = function () {}
foo = bar;

function baz(baz) { // `baz` is shadowed.
    baz = bar;
}

function qux() {
    const qux = bar;  // `qux` is shadowed.
}

由 TypeScript 處理

當使用 TypeScript 時,停用此規則是安全的,因為 TypeScript 的編譯器會強制執行此檢查。

版本

此規則在 ESLint v0.0.9 中引入。

資源

變更語言