-
Notifications
You must be signed in to change notification settings - Fork 3
Javascript: Code Style
Этот гайд является форком гайда для node.js.
В отличие от node.js мы будем использовать символы табуляции. Они лучше читаются в консоли, и удобнее настраивать их отображение с помощью пробелов.
Символ новой строки должен быть в UNIX-стиле (\n
). Виндовые окончания (\r\n
)
запрещены.
Настройте свой редактор на очистку trailing whitespaces. Пустая строка в конце файла допустима, но странно там видеть пять пустых строк подряд. Также следует настроить удаление trailing whitespaces в конце строк.
Не забывайте ставить ;
, например, после определения переменных
var Animal = function(name) {
this.name = name;
};
Animal.prototype.showName = function() {
$('#animal-name').text(this.name);
};
Следует ограничить строки кода 80-ю символами. Да, экраны стали больше за последние годы, а ваш мозг - нет. Используйте свободное место для split screen.
Используйте одинарные кавычки, кроме тех случаев, когда вы пишите JSON.
Правильно:
var foo = 'bar';
Неправильно:
var foo = "bar";
Открывающиеся фигурные скобки должны быть на той же строке, что и выражение
Правильно:
if (true) {
console.log('winning');
}
Неправильно:
if (true)
{
console.log('losing');
}
Также обратите внимание на использование пробела до и после условного выражения.
Одно выражение var
= одна переменная. Так легче менять строки местами.
Правильно:
var keys = ['foo', 'bar'];
var values = [23, 42];
var object = {};
while (keys.length) {
var key = keys.pop();
object[key] = values.pop();
}
Неправильно:
var keys = ['foo', 'bar'],
values = [23, 42],
object = {},
key;
while (keys.length) {
key = keys.pop();
object[key] = values.pop();
}
Переменный, свойства и имена функций должны быть в верблюжейНотации
. Также
они должны быть говорящими. Переменные из одного символа и необычные аббревиатуры
в общем случае использоваться не должны (односимвольные переменные допустимы в
качестве счетчиков внутри циклов, напирмер).
Правильно:
var adminUser = db.query('SELECT * FROM users ...');
Неправильно:
var admin_user = db.query('SELECT * FROM users ...');
Названия классов должны быть капитализированы: UpperCamelCase
.
Правильно:
function BankAccount() {
}
Неправильно:
function bank_Account() {
}
Константы должны быть объявлены как обычные переменные или статические свойства класса в верхнем регистре.
Правильно:
var SECOND = 1 * 1000;
function File() {
}
File.FULL_PERMISSIONS = 0777;
Неправильно:
const SECOND = 1 * 1000;
function File() {
}
File.fullPermissions = 0777;
Используйте короткие объявления на кадой строке. Оборачивайте ключи в кавычки только если ваш интерпретатор жалуется.
Правильно:
var a = ['hello', 'world'];
var b = {
good: 'code',
'is generally': 'pretty',
};
Неправильно:
var a = [
'hello', 'world'
];
var b = {"good": 'code'
, is generally: 'pretty'
};
Программирование - это не запоминание глупых правил. Используйте оператор тождественного равенства, ведь он работает ровно так, как ожидается.
Правильно:
var a = 0;
if (a === '') {
console.log('winning');
}
Неправильно:
var a = 0;
if (a == '') {
console.log('losing');
}
Тернарный оператор не следует размещать на одной строке, разделите его на несколько.
Правильно:
var foo = (a === b)
? 1
: 2;
Неправильно:
var foo = (a === b) ? 1 : 2;
Не расширяйте прототипы нативных объектов JavaScript.
Правильно:
var a = [];
if (!a.length) {
console.log('winning');
}
Неправильно:
Array.prototype.empty = function() {
return !this.length;
}
var a = [];
if (a.empty()) {
console.log('losing');
}
Любые нетривиальные условия должны быть присвоены говорящим переменным или функциям:
Правильно:
var isValidPassword = password.length >= 4 && /^(?=.*\d).{4,}$/.test(password);
if (isValidPassword) {
console.log('winning');
}
Неправильно:
if (password.length >= 4 && /^(?=.*\d).{4,}$/.test(password)) {
console.log('losing');
}
Старайтесь писать короткие функции. Хорошая функция вмещается на слайд, чтобы люди, сидяшие в последнем ряду в большой комнате, могли комфортно ее прочитать. Старайтесь ограничить себя примерно 15-ю строками на функцию.
Чтобы избежать глубокой вложенность if-выражений всегда выполняйте return значения как можно скорее.
Правильно:
function isPercentage(val) {
if (val < 0) {
return false;
}
if (val > 100) {
return false;
}
return true;
}
Неправильно:
function isPercentage(val) {
if (val >= 0) {
if (val < 100) {
return true;
} else {
return false;
}
} else {
return false;
}
}
В этом конкретном примере можно сократить код еще больше
function isPercentage(val) {
var isInRange = (val >= 0 && val <= 100);
return isInRange;
}
Не стесняйтесь давать замыканиям имена. Это показывает, что вы о них заботитесь и поможет при дебаге.
Правильно:
req.on('end', function onEnd() {
console.log('winning');
});
Неправильно:
req.on('end', function() {
console.log('losing');
});
Используйте замыкания, но не вкладывайте их друг в друга. Иначе ваш код превратится в кашу.
Правильно:
setTimeout(function() {
client.connect(afterConnect);
}, 1000);
function afterConnect() {
console.log('winning');
}
Неправильно:
setTimeout(function() {
client.connect(function() {
console.log('losing');
});
}, 1000);
Используйте слешы как для однострочных, так и для многострочных комментариев.
Правильно:
// 'ID_SOMETHING=VALUE' -> ['ID_SOMETHING=VALUE', 'SOMETHING', 'VALUE']
var matches = item.match(/ID_([^\n]+)=([^\n]+)/));
// This function has a nasty side effect where a failure to increment a
// redis counter used for statistics will cause an exception. This needs
// to be fixed in a later iteration.
function loadUser(id, cb) {
// ...
}
var isSessionValid = (session.expires < Date.now());
if (isSessionValid) {
// ...
}
Неправильно:
// Execute a regex
var matches = item.match(/ID_([^\n]+)=([^\n]+)/));
// Usage: loadUser(5, function() { ... })
function loadUser(id, cb) {
// ...
}
// Check if the session is valid
var isSessionValid = (session.expires < Date.now());
// If the session is valid
if (isSessionValid) {
// ...
}