热头条丨七个糟糕的 JavaScript 代码实践,看看自己这样操作过没有?
在我这几年的工作生涯中,我写过很多烂代码,对此我深有体会。
我的同事们一直认为我的代码是臭代码,但我认为他们不欣赏我的艺术,所以,今天我把自己之前踩过的坑,总结了一下,也希望可以帮助你避免这些糟糕的操作。
1.代码尽量写在一行哦,我的天啊!你愿意我做你的同事吗?
(相关资料图)
我只用一行代码就清除了一个网页的所有cookies,是不是很牛逼?
document.cookie.split(";").forEach(cookie => document.cookie = cookie.replace(/^ +/, "").replace(/=.*/, `=;expires=${new Date(0).toUTCString()};path=/`))
哦!请原谅我!没有一点可读性可言,我头疼,也许我应该这样做。
const cookies = document.cookie.split(";")cookies.forEach(cookie => { cookie = cookie.replace(/^ +/, "") // cookie = cookie.replace(/=.*/, `=;expires=${new Date(0).toUTCString()};path=/`) document.cookie = cookie})2.在控制台打印错误
你有这种编码习惯吗?只关注请求的成功状态,忽略失败的请求。
出于调试目的,我总是在控制台上打印错误消息。
try { fetch(url, { method: "post", ... })} catch (err) { // When the request goes wrong, we don"t have any perception console.log(err)}
或许我们应该向用户提供一条友好的警告消息,告诉他发生了错误。
try { fetch(url, { method: "post", ... })} catch (err) { Toast(err.message)}3.使用神奇的数字
我猜你已经多次看到这个神奇的数字,它的真正含义是什么?
或许只有他的第一作者才能看得懂!
// index1.jsif (status === 1 || status === 2) { // ...} else if (status === 3) { // ...}// index2.jsif (status === 1 || status === 2) { // ...}
我们可以定义常量来表示它的含义,如果我们能添加清晰简洁的注释就更好了。
const STATUS = { // It is an adult and has real-name authentication adultRealName: 1, // It is a minor and has real-name authentication minorRealName: 2, // Not real-name authentication notRealName: 3, // ...}// index1.jsif ([ STATUS.adultRealName, STATUS.minorRealName ].includes(status)) { // ...} else if (status === STATUS.notRealName) { // ...}// index2.jsif ([ STATUS.adultRealName, STATUS.minorRealName ].includes(status)) { // ...}4. 滥用回调函数
现在是 2023 年了,我们不应该再滥用回调了,那太可怕了。
那看起来我们是一个非常初级的前端开发工程师。
fetch("/a") .then((a) => { fetch("/b", { a }) .then((b) => { fetch("/c", { b }) .then((c) => { console.log(c) }) }) })
JavaScript 为我们提供了 await 关键字,所以让我们简化上面的代码。
const a = await fetch("/a")const b = await fetch("/b", { a })const c = await fetch("/c", { b })console.log(c)
哇,它使我们的代码更简单,具有更好的可读性和可维护性。
5.给函数设置10个参数这可能有点夸张,好吧,我想表达的是,如果一个函数被设计成传递很多参数,那么它的可读性就会变差,甚至会让我们不清楚如何使用它。
比如这个例子,我就晕了,不知道怎么给它传递正确的值。
const getUser = (name, weight, mobile, gender, address, hobby, ...) => { // ... return ...}getUser("fatfish", 100, 183, ....)
我们必须尝试重新发明 getUser,是的,使用一个对象来传递它需要的信息会让你看起来像一个专家。
const getUser = (options) => { const { name, weight, mobile, gender, address, hobby, ... } = options // ... return ...}getUser({ name: "fatfish", weight: 100, mobile: 183 ...})6. 使用+号将字符串转换为数字
仅使用 + 号将字符串转换为数字看起来很简单。
const str = "123456"const num = +strconsole.log(num) // 123456
但是使用 Number 或 parseInt 应该是一个更语义化和更清晰的选择。因为从他们身上可以看出我们的目的是转换成数字。
const str = "123456"const num1 = Number(str)const num3 = parseInt(str)console.log({ num1, num2 }) // { "num1": 123456, "num2": 123456 }7.直接修改node_modules中的代码
哇!这一定是一件超级离谱的事情,我直接修改了node_modules中的代码来解决第三个npm包的问题,因为它已经被git忽略了,所以我的电脑上只有我有那个部分。
后来项目移交给其他部门后,我修复的问题又出现了……
// .gitignorenode_modules/dist/// ...写在最后
朋友们,如果你还这些糟糕的操作,请及时调整过来,如果你还有一些其他不好的JavaScript习惯,也记得及时纠正。
关键词:
责任编辑:宋璟
-
热头条丨七个糟糕的 JavaScript 代码实践,看看自己这样操作过没有?
-
当东方甄选遇到大湾区好物!东方甄选百人团首次打造广州“游轮直播”专场
-
冬干连春旱 春灌用水如何保障
-
FTX 将从该对冲基金中收回 400 多万美元:为什么?
-
高压锅和电压力锅哪个好
-
热推荐:长安EadoXT将获得比轿车更具运动感的图像
-
2022年我国脱贫人口小额信贷累计发放933.5亿元|全球今头条
-
当前最新:2x1000MW!大唐国际吕四港发电二期工程可研、环评等招标
-
英文商务书信_关于英文商务书信的简介_聚看点
-
电脑怎么下软件不带其它的东西(电脑怎么下软件)
-
918鸣笛是什么意思
-
歌手苏允的歌曲_苏允的歌曲大全|信息
-
世界今热点:电脑桌面改回c盘_电脑桌面c盘移到d盘
-
今日聚焦!足球言论丨阿森纳传奇门将希曼被问及拉姆斯代尔是否...
-
中国园林博物馆赏花地点及路线
-
lol无限火力,lol无限火力入口在哪 lol无限乱斗怎么进
-
中国的斡旋成功,膨胀了印度的自信,中东的一团乱麻,我上我也行
-
腾讯2022年业绩公布!盈利1882.4亿元、微信月活超13亿_独家焦点
-
锋范与桑塔纳的区别是什么 快讯
-
和讯个股快报:2023年03月22日 荣联科技(002642)该股换手率大于8%-天天观焦点
-
本季英超数据之最哈兰德进球最多 天赋异禀还是后天勤奋哈兰德为何总在合适时间出现在合适位置(今日/头条)
-
江西省婺源县发布暴雨黄色预警
-
章源钨业:融资净偿还395.65万元,融资余额2.97亿元(03-21)_全球短讯
-
陈伟霆演的电影_陈伟霆演的电影上映时间
-
图解伟星股份年报:第四季度单季净利润同比减163.59%
-
高考平行志愿是什么意思有何特点_高考平行志愿是什么意思 每日报道
-
重点看创业板|全球速递
-
无垠的太空第三季完整版_无垠的太空第三季
-
家公和我的关系怎么填_家公和我的关系写什么
-
铜陵化学工业集团有限公司原党委书记、董事长陈嘉生严重违纪违法被开除党籍和公职
-
地毯之乡“牵线做媒” “链”上企业共话发展
-
以下哪一个不是网络营销的优势和劣势_以下哪一个不是网络营销的优势 _
-
001696股票 美的股票代码是多少
-
环球微速讯:毕节学院学报官网_毕节学院
-
大连居民用水多少钱一吨