做者 | Daniel Andersonjavascript
本文最初发布于 Medium 网站,经原做者受权后翻译和分享。java
下面的编码标准是我对上述几点有帮助的见解。git
这很重要,由于JavaScript是一种动态语言,所以使用==可能会给您带来意想不到的结果,由于它容许类型不一样。es6
Fail:github
if (val == 2)
复制代码
Pass:web
if (val === 2)
复制代码
使用 let
将有助于避免 JavaScript
中各类 var
引发的做用域问题。app
Fail:函数
var myVar = 10;
复制代码
Pass:网站
let myVar = 10;
复制代码
这阻止了开发人员尝试更改不该该作的事情,而且确实有助于提升可读性。编码
Fail:
let VAT_PERCENT = 20;
复制代码
Pass:
const VAT_PERCENT = 20;
复制代码
尽管这在 JavaScript
中是可选的,并不像其它语言同样须要分号做为语句终止符。可是使用 ;
有助于使代码保持一致。
Fail:
const VAT_PERCENT = 20;
let amount = 10
return addVat(amount, vatPercent)
复制代码
Pass:
const vatPercent = 20;
let amount = 10;
return addVat(amount, vatPercent);
复制代码
let
应该使用驼峰命名。
const
若是在文件的顶部使用大写的蛇形命名法。若是不在文件顶部,请使用驼峰命名。
class
应该是帕斯卡命名法:MyClass
functions
函数应该是驼峰命名法:myFunction
模板字符串中容许嵌入表达式。
Fail:
let fullName = firstName + " " + lastName;
复制代码
Pass:
let fullName = `${firstName} ${lastName}`;
复制代码
箭头函数是编写函数表达式的更简洁的语法。
Fail:
var multiply = function(a, b) {
return a* b;
};
复制代码
Pass:
const multiply = (a, b) => { return a * b};
复制代码
全部控制结构都必须使用花括号(例如,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();
}
复制代码
Fail:
if (myNumber === 0)
{
doSomething();
}
复制代码
Pass:
if (myNumber === 0) {
doSomething();
}
复制代码
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);
复制代码
经过上面的示例能够看出,减小嵌套以后,会变得容易阅读。
在 JavaScript
中,若是你在调用函数时没有传递参数,则它的值就是 undefined
Fail:
myFunction(a, b) {
return a + b;
}
复制代码
Pass:
myFunction(a = 0, b = 0) {
return a + b;
}
复制代码
我一般会尝试不使用 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;
}
复制代码
Fail:
import * as Foo from './Foo';
复制代码
Pass:
import Foo from './Foo';
复制代码
Fail:
if (isValid === true)
if (isValid === false)
复制代码
Pass:
if (isValid)
if (!isValid)
复制代码
Fail:
const boo = a ? a : b;
复制代码
Pass:
const boo = a || b;
复制代码
任何语言的编码标准均可以真正帮助提升应用程序的可读性和可维护性。若是你在团队中工做,那么一件很难的事情就是强制执行编码标准。这里有一些建议能够帮助你:
原文连接: https://medium.com/javascript-in-plain-english/19-simple-javascript-coding-standards-to-keep-your-code-clean-7422d6f9bc0
好嘛,若是看到这里,说明是真爱了。要不要给个人 Github 增长一个 star。
若有翻译不当的地方,多多包涵,欢迎在评论区指正~