解决 Unexpectedlexicaldeclarationincaseblock的问题
亲测可用,若有疑问请私信
使用新版的 es-lint 的时候扫描旧的项目,发现报了
Unexpected lexical declaration in case block(no-case-declarations)
这么一个错误提示
当时很奇怪,就去查了一下文档,发现中文文档中解释比较简单
该规则禁止词法声明 (let、const、function 和 class) 出现在 case或default 子句中。
几番实验后,其实归根结底是代码作用域的问题:
switch (2) {
case 1:
function f () {console.log('Wanna a girl friend !')}
break
case 2:
f() // 会输出:Wanna a girl friend !
break
}
switch (1) {
case 1:
let foo = 1
break
case 2:
let foo = 2
console.log(foo) // 会报错:Uncaught SyntaxError: Identifier 'foo' has already been declared
break
}
如上实验可知,就算switch 逻辑没有走到 case 1 的代码块,由于作用域提升,会导致case 1 影响到case 2
所以,eslint 会对这种情况做校验,现在必须 使用花括号将代码块确定具体的作用域
switch (1) {
case 1: {
// do something
break
}
}
从而限制上述问题的发生
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 上周热点回顾(2.24-3.2)
2021-11-04 throw和throws有什么不同?