switch-case 和 if-else 在分支处理上的不同
switch case 不同分支里申明同一个变量会报错,因为swicth case 不同的分支仍处于同一个作用域scope。但是if else 却没有注意的问题。
// Cannot redeclare block-scoped variable 'a'.
switch(num){
case 1:
const a = 'a'
return a
case 2:
const a = 'b'
return a
case 3:
const a = 'c'
return a
}
思路:为每个case 起一个独立的作用域,就如同if-else 花括号{}起到了隔离的作用。
switch (num) {
case 1: {
const a = 'a'
return a
}
case 2: {
const a = 'b'
return a
}
case 3: {
const a = 'c'
return a
}
}
标签:case,return,else,switch,申明,const
From: https://www.cnblogs.com/wanglei1900/p/17614797.html