七个糟糕的 JavaScript 代码实践,看看自己这样操作过没有?

疑难杂症   2023-03-26 09:03   601   1  

在我这几年的工作生涯中,我写过很多烂代码,对此我深有体会。

3826e9614b887a904e07295f670b08932f1acf.jpg

我的同事们一直认为我的代码是臭代码,但我认为他们不欣赏我的艺术,所以,今天我把自己之前踩过的坑,总结了一下,也希望可以帮助你避免这些糟糕的操作。

1.代码尽量写在一行

哦,我的天啊!你愿意我做你的同事吗?

我只用一行代码就清除了一个网页的所有cookies,是不是很牛逼?

document.cookie.split(';').forEach(cookie => document.cookie = cookie.replace(/^ +/, '').replace(/=.*/, `=;expires=${new Date(0).toUTCString()};path=/`))

哦!请原谅我!没有一点可读性可言,我头疼,也许我应该这样做。

   document..()
cookies.(  {
    .(, ) 
    .(,  Date().())
  document.  
})

2.在控制台打印错误

你有这种编码习惯吗?只关注请求的成功状态,忽略失败的请求。

出于调试目的,我总是在控制台上打印错误消息。

 {
  fetch(url, {
    : ,
    
  })
}  (err) {
  
  console.(err)
}

或许我们应该向用户提供一条友好的警告消息,告诉他发生了错误。

 {
  fetch(url, {
    : ,
    
  })
}  (err) {
  Toast(err.)
}

3.使用神奇的数字

我猜你已经多次看到这个神奇的数字,它的真正含义是什么?

或许只有他的第一作者才能看得懂!

 (status    status  ) {
  
}   (status  ) {
  
}



 (status    status  ) {
  
}

我们可以定义常量来表示它的含义,如果我们能添加清晰简洁的注释就更好了。

   {
  
  : ,
  
  : ,
  
  : ,
  
}



 ([ STATUS., STATUS. ].(status)) {
  
}   (status  STATUS.) {
  
}

 ([ STATUS., STATUS. ].(status)) {
  
}

4. 滥用回调函数

现在是 2023 年了,我们不应该再滥用回调了,那太可怕了。

那看起来我们是一个非常初级的前端开发工程师。

fetch()
  .(()  {
    fetch(, {  })
      .(()  {
        fetch(, {  })
          .(()  {
            console.()
          })
      })
  })

JavaScript 为我们提供了 await 关键字,所以让我们简化上面的代码。

    fetch()
    fetch(, {  })
    fetch(, {  })


console.(c)

哇,它使我们的代码更简单,具有更好的可读性和可维护性。

5.给函数设置10个参数

这可能有点夸张,好吧,我想表达的是,如果一个函数被设计成传递很多参数,那么它的可读性就会变差,甚至会让我们不清楚如何使用它。

比如这个例子,我就晕了,不知道怎么给它传递正确的值。

   (, , , , , , )  {
  
   
}


getUser(, , , .)

我们必须尝试重新发明 getUser,是的,使用一个对象来传递它需要的信息会让你看起来像一个专家。

   ()  {
   { , , , , , ,  }  
  
   
}


getUser({
  : ,
  : ,
  : 
  
})

6. 使用+号将字符串转换为数字

仅使用 + 号将字符串转换为数字看起来很简单。

   
   str


console.(num)

但是使用 Number 或 parseInt 应该是一个更语义化和更清晰的选择。因为从他们身上可以看出我们的目的是转换成数字。

   
   Number(str)
   parseInt(str)


console.({ ,  })

7.直接修改node_modules中的代码

哇!这一定是一件超级离谱的事情,我直接修改了node_modules中的代码来解决第三个npm包的问题,因为它已经被git忽略了,所以我的电脑上只有我有那个部分。

后来项目移交给其他部门后,我修复的问题又出现了……

node_modules
dist

写在最后

朋友们,如果你还这些糟糕的操作,请及时调整过来,如果你还有一些其他不好的JavaScript习惯,也记得及时纠正。

博客评论
还没有人评论,赶紧抢个沙发~
发表评论
说明:请文明发言,共建和谐网络,您的个人信息不会被公开显示。
闲言碎语
你总嫌有些人懒,说得好像你勤快了就真能干出什么大事儿一样。
赞赏支持

如果觉得博客文章对您有帮助,异或土豪有钱任性,可以通过以下扫码向我捐助。也可以动动手指,帮我分享和传播。您的肯定,是我不懈努力的动力!感谢各位亲~