一些eslint问题报错记录

错误1

Unexpected lexical declaration in case block no-case-declarations
https://blog.csdn.net/u010227042/article/details/119519399
该规则禁止词法声明(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
  }
}

从而限制上述问题的发生

posted @   zeal666  阅读(143)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!
点击右上角即可分享
微信分享提示