이 목록은 여러분의 프로젝트가 제대로 shitcode가 되기 위해 따라야 하는 규칙들입니다.
만일 여러분의 레포지토리가 shitcode의 규칙을 따른다면, 여러분은 다음과 같은 "state-of-the-art shitcode" 뱃지를 사용할 수 있습니다:
뱃지를 만들기 위한 마크다운 소스코드:
[![State-of-the-art Shitcode](https://img.shields.io/static/v1?label=State-of-the-art&message=Shitcode&color=7B5804)](https://github.com/trekhleb/state-of-the-art-shitcode)
적은 키 입력은, 여러분의 시간을 아끼게 해줍니다.
Good 👍🏻
let a = 42;
Bad 👎🏻
let age = 42;
다양성을 축하합시다.
Good 👍🏻
let wWidth = 640;
let w_height = 480;
Bad 👎🏻
let windowWidth = 640;
let windowHeight = 480;
어차피 아무도 당신의 코드를 읽지 않을 것입니다.
Good 👍🏻
const cdr = 700;
Bad 👎🏻
자주 작성되는 주석은 '왜'가 아니라 '무엇'인지를 포함해야 합니다. 만일 코드에서 '무엇'이 명확하지 않으면, 코드가 너무 흐트러질 수 있기 때문입니다.
// 700ms라는 수는 UX A/B 테스트 결과에 기초하여 경험적으로 계산된 것입니다.
// @보세요: <실험 또는 JIRA 작업에 관련된 것 또는 숫자 700에 대해 상세히 설명하는 것에 대한 링크>
const callbackDebounceRate = 700;
만일 "주석 없음"의 원칙을 위반했다면 적어도 주석은 코드 작성에 사용하는 언어와 다른 언어로 작성하세요. 만일 여러분의 모국어가 영어라면 여러분은 이 원칙을 위반해도 괜찮습니다.
Good 👍🏻
// Закриваємо модальне віконечко при виникненні помилки.
toggleModal(false);
Bad 👎🏻
// Hide modal window on error.
toggleModal(false);
다양성을 축하합시다.
Good 👍🏻
let i = ['tomato', 'onion', 'mushrooms'];
let d = [ "ketchup", "mayonnaise" ];
Bad 👎🏻
let ingredients = ['tomato', 'onion', 'mushrooms'];
let dressings = ['ketchup', 'mayonnaise'];
Good 👍🏻
document.location.search.replace(/(^\?)/,'').split('&').reduce(function(o,n){n=n.split('=');o[n[0]]=n[1];return o},{})
Bad 👎🏻
document.location.search
.replace(/(^\?)/, '')
.split('&')
.reduce((searchParams, keyValuePair) => {
keyValuePair = keyValuePair.split('=');
searchParams[keyValuePair[0]] = keyValuePair[1];
return searchParams;
},
{}
)
오류가 발생할 때마다 다른 사람이 그 오류를 알 필요는 없습니다. 로그도 없고, 오류 모달도 없이, 싸늘하게.
Good 👍🏻
try {
// 무언가 예견 불가능한 것.
} catch (error) {
// 쉿... 🤫
}
Bad 👎🏻
try {
// 무언가 예견 불가능한 것.
} catch (error) {
setErrorMessage(error.message);
// and/or
logError(error);
}
세계적인 원칙입니다.
Good 👍🏻
let x = 5;
function square() {
x = x ** 2;
}
square(); // 이제 x는 25입니다.
Bad 👎🏻
let x = 5;
function square(num) {
return num ** 2;
}
x = square(x); // 이제 x는 25입니다.
혹시 모르니까요.
Good 👍🏻
function sum(a, b, c) {
const timeout = 1300;
const result = a + b;
return a + b;
}
Bad 👎🏻
function sum(a, b) {
return a + b;
}
Good 👍🏻
function sum(a, b) {
return a + b;
}
// 형식이 없으면 신이 나요.
const guessWhat = sum([], {}); // -> "[object Object]"
const guessWhatAgain = sum({}, []); // -> 0
Bad 👎🏻
function sum(a: number, b: number): ?number {
// 자바스크립트에서 반환 및/또는 타입검사를 하지 않은 경우를 커버하는 조건
if (typeof a !== 'number' && typeof b !== 'number') {
return undefined;
}
return a + b;
}
// 이 경우는 반환/컴파일의 경우에 실패할 것입니다.
const guessWhat = sum([], {}); // -> undefined
이 것이 여러분의 "플랜 B" 입니다.
Good 👍🏻
function square(num) {
if (typeof num === 'undefined') {
return undefined;
}
else {
return num ** 2;
}
return null; // 이 것이 나의 "플랜 B".
}
Bad 👎🏻
function square(num) {
if (typeof num === 'undefined') {
return undefined;
}
return num ** 2;
}
새처럼 되자 - 둥지를 틀자, 둥지를 틀자, 둥지를 틀자.
Good 👍🏻
function someFunction() {
if (condition1) {
if (condition2) {
asyncFunction(params, (result) => {
if (result) {
for (;;) {
if (condition3) {
}
}
}
})
}
}
}
Bad 👎🏻
async function someFunction() {
if (!condition1 || !condition2) {
return;
}
const result = await asyncFunction(params);
if (!result) {
return;
}
for (;;) {
if (condition3) {
}
}
}
들여쓰기는 에디터에서 복잡한 코드의 공간을 더 차지하기 때문에 들여쓰기를 피합시다. 만약 피하고 싶지 않다면 그냥 그들을 엉망으로 가지고 노세요.
Good 👍🏻
const fruits = ['apple',
'orange', 'grape', 'pineapple'];
const toppings = ['syrup', 'cream',
'jam',
'chocolate'];
const desserts = [];
fruits.forEach(fruit => {
toppings.forEach(topping => {
desserts.push([
fruit,topping]);
});})
Bad 👎🏻
const fruits = ['apple', 'orange', 'grape', 'pineapple'];
const toppings = ['syrup', 'cream', 'jam', 'chocolate'];
const desserts = [];
fruits.forEach(fruit => {
toppings.forEach(topping => {
desserts.push([fruit, topping]);
});
})
새로운 설치가 있을 때마다 제어되지 않는 방식으로 dependencies를 업데이트 하세요. 왜 과거에 집착하죠, 최첨단 라이브러리 버전을 사용합시다.
Good 👍🏻
$ ls -la
package.json
Bad 👎🏻
$ ls -la
package.json
package-lock.json
boolean 값이 무엇을 의미하는지 동료들이 생각할 공간을 남겨둡시다.
Good 👍🏻
let flag = true;
Bad 👎🏻
let isDone = false;
let isEmpty = false;
프로그램 로직을 읽을 수 있는 조각으로 나누지 맙시다. 만일 여러분이 사용하는 IDE의 검색이 중단되고 필수적인 파일 또는 function을 찾을 수 없다면 어떻게 하겠습니까?
- 한 개의 파일에 10000 줄의 코드가 있어도 괜찮습니다.
- 한 개의 function에 1000 줄의 코드가 있어도 괜찮습니다.
- 많은 서비스들 (써드파티와 내부기능, 몇몇 헬퍼들, ORM과 jQuery slider로 직접 작성된 자료들 ) 이
service.js
하나에 들어있다구요? 괜찮습니다.
이 것은 중복되고 불필요한 일의 양입니다.
특히 둘 이상의 개발자가 있는 팀인 경우 원하는 대로 코드를 작성합니다. 이것은 '자유'의 규칙입니다.
그리고 당분간은 그렇게 지내세요.
어플에서 사용하지 않는 코드를 삭제하지 마세요. 기껏해야, 주석정도 입니다.