javascript plugin eslint

simuruk wiki

switch-case

  • eslint unexpected lexical declaration in case block 에러
  • let 변수를 사용할때 중괄호 블록으로 감싸야 합니다.
  • switch의 case문 하나하나가 함수라고 생각을 하면 let 키워드를 사용한 변수의 범위가 모호해지기 때문이라고 생각합니다.
  • https://eslint.org/docs/rules/no-case-declarations
 1 /*eslint no-case-declarations: "error"*/
 2 /*eslint-env es6*/
 3 
 4 // Declarations outside switch-statements are valid
 5 const a = 0;
 6 
 7 switch (foo) {
 8     // The following case clauses are wrapped into blocks using brackets
 9     // let 변수를 사용할때 중괄호 블록으로 감싸거나 정의된 함수로 교환하거나 내부함수로 정의해야 함
10     case 1: {
11         let x = 1;
12         break;
13     }
14     case 2: {
15         const y = 2;
16         break;
17     }
18     case 3: {
19         function f() {}
20         break;
21     }
22     case 4:
23         // Declarations using var without brackets are valid due to function-scope hoisting
24         var z = 4;
25         break;
26     default: {
27         class C {}
28     }
29 }

참고링크