15个简单的JS编码标准

简介: 15个简单的JS编码标准

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

保持代码一致
易于阅读和理解
易于维护
下面的编码标准是我对上述几点有帮助的看法。

  1. 比较时使用 === 代替 ==
    这很重要,因为JavaScript是一种动态语言,因此使用==可能会给您带来意想不到的结果,因为它允许类型不同。

Fail:

if (val == 2)

Pass:

if (val === 2)

  1. 永远不要使用 var,使用 let 来代替
    使用 let 将有助于避免 JavaScript 中各种 var 引起的作用域问题。

Fail:

var myVar = 10;

Pass:

let myVar = 10;

  1. 使用 const 代替 let
    这阻止了开发人员尝试更改不应该做的事情,并且确实有助于提高可读性。

Fail:

let VAT_PERCENT = 20;

Pass:

const VAT_PERCENT = 20;

  1. 始终使用分号(;)
    尽管这在 JavaScript 中是可选的,并不像其它语言一样需要分号作为语句终止符。但是使用 ; 有助于使代码保持一致。

Fail:

const VAT_PERCENT = 20;

let amount = 10

return addVat(amount, vatPercent)

Pass:

const vatPercent = 20;

let amount = 10;

return addVat(amount, vatPercent);

  1. JavaScript中的命名约定
    let 应该使用驼峰命名。
    const 如果在文件的顶部使用大写的蛇形命名法。如果不在文件顶部,请使用驼峰命名。
    class 应该是帕斯卡命名法:MyClass
    functions 函数应该是驼峰命名法:myFunction
  2. 拼接字符串时使用模板字符串
    模板字符串中允许嵌入表达式。

Fail:

let fullName = firstName + " " + lastName;

Pass:

let fullName = ${firstName} ${lastName};

  1. 尽可能使用ES6箭头函数
    箭头函数是编写函数表达式的更简洁的语法。

Fail:

var multiply = function(a, b) {

return a* b;

};

Pass:

const multiply = (a, b) => { return a * b};

  1. 始终在控制结构周围使用大括号
    所有控制结构都必须使用花括号(例如,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();

}

  1. 确保大括号从同一行开始,中间有空格
    Fail:

if (myNumber === 0)

{

doSomething();

}

Pass:

if (myNumber === 0) {

doSomething();

}

  1. 尝试减少嵌套
    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);

通过上面的示例可以看出,减少嵌套之后,会变得容易阅读。
//代码效果参考:http://www.zidongmutanji.com/zsjx/52805.html

  1. 尽可能使用默认参数
    在 JavaScript 中,如果你在调用函数时没有传递参数,则它的值就是 undefined

Fail:

myFunction(a, b) {

return a + b;

}

Pass:

myFunction(a = 0, b = 0) {

return a + b;

}

  1. 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;

}

  1. 不要使用通配符导入
    Fail:

import * as Foo from './Foo';

Pass:

import Foo from './Foo';

  1. 使用布尔值的快捷方式
    Fail:

if (isValid === true)

if (isValid === false)

Pass:

if (isValid)

if (!isValid)

  1. 尝试避免不必要的三元语句
    Fail:

const boo = a ? a : b;

Pass:

const boo = a || b;

总结

任何语言的编码标准都可以真正帮助提高应用程序的可读性和可维护性。如果你在团队中工作,那么一件很难的事情就是强制执行编码标准。这里有一些建议可以帮助你:

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

相关文章
|
6月前
|
JavaScript 前端开发
JS编码标准掌握后让你的代码更整洁
JS编码标准掌握后让你的代码更整洁
57 8
|
2月前
|
JavaScript 前端开发
JavaScript中的原型 保姆级文章一文搞懂
本文详细解析了JavaScript中的原型概念,从构造函数、原型对象、`__proto__`属性、`constructor`属性到原型链,层层递进地解释了JavaScript如何通过原型实现继承机制。适合初学者深入理解JS面向对象编程的核心原理。
35 1
JavaScript中的原型 保姆级文章一文搞懂
|
6月前
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp的客户关系管理系统附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp的客户关系管理系统附带文章源码部署视频讲解等
114 2
|
2月前
JS+CSS3文章内容背景黑白切换源码
JS+CSS3文章内容背景黑白切换源码是一款基于JS+CSS3制作的简单网页文章文字内容背景颜色黑白切换效果。
22 0
|
6月前
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp的小区物流配送系统附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp的小区物流配送系统附带文章源码部署视频讲解等
161 4
|
6月前
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp的宠物援助平台附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp的宠物援助平台附带文章源码部署视频讲解等
91 4
|
6月前
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp的宠物交易平台附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp的宠物交易平台附带文章源码部署视频讲解等
84 4
|
6月前
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp的大学生入伍人员管理系统附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp的大学生入伍人员管理系统附带文章源码部署视频讲解等
101 4
|
6月前
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp宿舍管理系统的附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp宿舍管理系统的附带文章源码部署视频讲解等
95 3
|
6月前
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp的家政平台附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp的家政平台附带文章源码部署视频讲解等
77 3