15个简单的JS编码标准让你的代码更整洁

作者 | Daniel Anderson
本文最初发布于 Medium 网站,经原作者授权后翻译和分享。

编码标准可以帮助以下方面:

保持代码一致
易于阅读和理解
易于维护

下面的编码标准是我对上述几点有帮助的看法。

  1. 比较时使用 === 代替 ==
    这很重要,因为JavaScript是一种动态语言,因此使用==可能会给您带来意想不到的结果,因为它允许类型不同。
    Fail:
    if (val == 2)复制代码
    Pass:
    if (val === 2)复制代码
  2. 永远不要使用 var,使用 let 来代替
    使用 let 将有助于避免 JavaScript 中各种 var 引起的作用域问题。
    Fail:
    var myVar = 10;复制代码
    Pass:
    let myVar = 10;复制代码
  3. 使用 const 代替 let
    这阻止了开发人员尝试更改不应该做的事情,并且确实有助于提高可读性。
    Fail:
    let VAT_PERCENT = 20;复制代码
    Pass:
    const VAT_PERCENT = 20;复制代码
  4. 始终使用分号(;)
    尽管这在 JavaScript 中是可选的,并不像其它语言一样需要分号作为语句终止符。但是使用 ; 有助于使代码保持一致。
    Fail:
    const VAT_PERCENT = 20;let amount = 10return addVat(amount, vatPercent)复制代码
    Pass:
    const vatPercent = 20;let amount = 10;return addVat(amount, vatPercent);复制代码
  5. JavaScript中的命名约定

let 应该使用驼峰命名。
const 如果在文件的顶部使用大写的蛇形命名法。如果不在文件顶部,请使用驼峰命名。
class 应该是帕斯卡命名法:MyClass
functions 函数应该是驼峰命名法:myFunction

  1. 拼接字符串时使用模板字符串
    模板字符串中允许嵌入表达式。
    Fail:
    let fullName = firstName + " " + lastName;复制代码
    Pass:
    let fullName = ${firstName} ${lastName};复制代码
  2. 尽可能使用ES6箭头函数
    箭头函数是编写函数表达式的更简洁的语法。
    Fail:
    var multiply = function(a, b) { return a* b;};复制代码
    Pass:
    const multiply = (a, b) => { return a * b};复制代码
  3. 始终在控制结构周围使用大括号
    所有控制结构都必须使用花括号(例如,if,else,for,do,while等),这样后期维护时,不容易出错。
    Fail:
    if (valid) doSomething();if (amount > 100) doSomething();else if(amount > 200) doSomethingElse();复制代码
    Pass:
    if (valid) { doSomething();}if (amount > 100) { doSomething();} else if(amount > 200) { doSomethingElse();}复制代码
  4. 确保大括号从同一行开始,中间有空格
    Fail:
    if (myNumber === 0){ doSomething();}复制代码
    Pass:
    if (myNumber === 0) { doSomething();}复制代码
  5. 尝试减少嵌套
    if 内的 if 会变得混乱并且很难阅读。有时你可能无法解决问题,但是可以好好卡看看代码结构,看看是否可以改进。
    Fail:
    if (myNumber > 0) { if (myNumber > 100) { if (!hasDiscountAlready) { return addDiscountPercent(0); } else { return addDiscountPercent(10); } } else if (myNumber > 50) { if (hasDiscountAlready) { return addDiscountPercent(5); } } else { if (!hasDiscountAlready) { return addDiscountPercent(0); } else { return addDiscountPercent(1); } }} else { error();}复制代码
    Pass:
    if (myNumber <= 0) { return error;}if (!hasDiscountAlready) { return addDiscountPercent(0);}if (myNumber > 100) { return addDiscountPercent(10);}if (myNumber > 50) { return addDiscountPercent(5);}return addDiscountPercent(1);复制代码
    通过上面的示例可以看出,减少嵌套之后,会变得容易阅读。
  6. 尽可能使用默认参数
    在 JavaScript 中,如果你在调用函数时没有传递参数,则它的值就是 undefined
    Fail:
    myFunction(a, b) { return a + b;}复制代码
    Pass:
    myFunction(a = 0, b = 0) { return a + b;}复制代码
  7. Switch 语句应使用 break 并具有 default
    我通常会尝试不使用 switch 语句,但是你确实想使用它,请确保每个条件都 break ,并写了 defalut。
    Fail:
    switch (myNumber){ case 10: addDiscountPercent(0); case 20: addDiscountPercent(2); case 30: addDiscountPercent(3);}复制代码
    Pass:
    switch (myNumber){ case 10: addDiscountPercent(0); break; case 20: addDiscountPercent(2); break; case 30: addDiscountPercent(3); break; default: addDiscountPercent(0); break;}复制代码
  8. 不要使用通配符导入
    Fail:
    import * as Foo from ‘./Foo’;复制代码
    Pass:
    import Foo from ‘./Foo’;复制代码
  9. 使用布尔值的快捷方式
    Fail:
    if (isValid === true)if (isValid === false)复制代码
    Pass:
    if (isValid)if (!isValid)复制代码
  10. 尝试避免不必要的三元语句
    Fail:
    const boo = a ? a : b;复制代码
    Pass:
    const boo = a || b;复制代码
    总结
    任何语言的编码标准都可以真正帮助提高应用程序的可读性和可维护性。如果你在团队中工作,那么一件很难的事情就是强制执行编码标准。这里有一些建议可以帮助你:

代码审查,逐行Pass代码。
整理或使用某种代码分析器
创建新内容时,让你们的一位高级开发人员初始化,其他开发人员可以使用该代码作为指导。

原文链接: https://medium.com/javascript-in-plain-english/19-simple-javascript-coding-standards-to-keep-your-code-clean-7422d6f9bc0

作者:刘小夕
链接:https://juejin.im/post/5f0dd73ff265da22f6163651

服务推荐

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值