版本

no-global-assign

禁止賦值給原生物件或唯讀全域變數

建議

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

JavaScript 環境包含許多內建的全域變數,例如瀏覽器中的 window 和 Node.js 中的 process。在幾乎所有情況下,您都不希望將值賦予這些全域變數,因為這樣做可能會導致無法存取重要功能。例如,您可能不希望在瀏覽器程式碼中執行此操作

window = {};

雖然像 window 這樣的範例很明顯,但 JavaScript 環境通常會提供數百個內建的全域物件。很難知道您是否正在賦值給全域變數。

規則詳情

此規則禁止修改唯讀全域變數。

ESLint 具有將全域變數設定為唯讀的功能。

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

在遊樂場中開啟
/*eslint no-global-assign: "error"*/

Object = null
undefined = 1
在遊樂場中開啟
/*eslint no-global-assign: "error"*/
/*global window:readonly*/

window = {}

此規則的 正確 程式碼範例

在遊樂場中開啟
/*eslint no-global-assign: "error"*/

a = 1
var b = 1
b = 2
在遊樂場中開啟
/*eslint no-global-assign: "error"*/
/*global onload:writable*/

onload = function() {}

選項

此規則接受 exceptions 選項,可用於指定允許重新賦值的內建清單

{
    "rules": {
        "no-global-assign": ["error", {"exceptions": ["Object"]}]
    }
}

何時不使用它

如果您嘗試覆寫其中一個原生物件。

版本

此規則在 ESLint v3.3.0 中引入。

資源

變更語言