在线文档教程
Eslint
规则 | Rules

no-case-declarations

在case/default子句中禁止词法声明(无大小写声明)

"extends": "eslint:recommended"配置文件中的属性启用此规则。

该规则禁止词法声明(letconstfunctionclass在)case/default条款。原因在于,词汇声明在整个开关块中是可见的,但它只在分配时才被初始化,这只有在达到定义的情况下才会发生。

确保词汇声明仅适用于当前案例子句将您的子句包含在块中。

规则细节

此规则旨在防止访问未初始化的词汇绑定以及跨越事例子句访问提升的功能。

此规则的错误代码示例:

/*eslint no-case-declarations: "error"*/ /*eslint-env es6*/ switch (foo) { case 1: let x = 1; break; case 2: const y = 2; break; case 3: function f() {} break; default: class C {} }

此规则的正确代码示例:

/*eslint no-case-declarations: "error"*/ /*eslint-env es6*/ // Declarations outside switch-statements are valid const a = 0; switch (foo) { // The following case clauses are wrapped into blocks using brackets case 1: { let x = 1; break; } case 2: { const y = 2; break; } case 3: { function f() {} break; } case 4: // Declarations using var without brackets are valid due to function-scope hoisting var z = 4; break; default: { class C {} } }

何时不使用它

如果您依赖于通过行为并希望访问大小写块中引入的绑定。

相关规则

  • no-fallthroughVersion此规则是在ESLint 1.9.0.Resources中引入的