클린코드 작성하기 - 1

2022. 8. 31. 17:14

클린코드에 대해서 항상 많은 고민을 했습니다.

기능 구현에만 앞선던 코드들을 어디 내놓으려니 부끄럽기도 합니다.

팀원들에게 보여줄 수 있고, 그들이 한번에 이해하기 쉬운 코드를 짜야겠다 라는 생각으로

자바스크립트 클린코드 에 대한 공부를 시작했습니다.

클린코드에 대해 고민하기

- 남이 적은 코드가 항상 맞진 않습니다.

- 물론 내 코드도 항상 옳지 않습니다.

- 항상 열린 태도로 여러 코드를 읽어보고 판단하는 것이 중요합니다

JavaScript 특성 파악하기

JS 의 폭발적인 성장은 Node.js 가 생기면서 부터 입니다.

Node.js는 크롬 v8 엔진으로 빌드 된 자바스크립트 실행 환경입니다.

현재는 Electron처럼 자바스크립트로 데스크탑 애플리케이션을 만드는 프레임워크도 있어 많은 프로그램을 만듭니다.

노션이나 VSCode 또한 js 기반으로 만들어졌다고 합니다. 🫢

Js는 치명적인 단점이 있습니다.

런타임 중에 내용이 변경되는 특성이 있는데 몽키 패치🐒라고도 불립니다.

var 지양하기

let 과 const는 ES6 부터 생겼습니다.

var는 함수 스코프이고, let & const는 블록 단위 스코프를 갖고 있습니다.

var는 선언한 내용이 다시 중복 선언이 가능하기 때문에 코드가 길어질 경우 위험에 노출됩니다.

var global= 1
  if(global===1){
      global = 2
  }
global => 2

전역 변수로 global 을 만들어서 사용해서 다른 스코프에서 변경하면 원래의 값이 변경됩니다.

let global = 1
  if(global===1){
      global = 2
      global >> 2
  }
global >> 1

하지만 let으로 선언하면 블록 안에서만 변경되기 때문에 블록 밖에서는 원래의 값을 사용가능합니다.

const global = 1
    if(global===1){
        let global = 2
        global >> 2
    }
global >> 1

블록이 다르기 때문에 두번 선언하더라도 에러가 발생하지 않습니다.

전역공간을 사용하지 말라

전역공간 : 최상위 환경

  • global - node JS 환경
  • window - 브라우저 환경

스코프를 나눠서 작업을 해야 하지만, 다른 곳에서도 사용이 가능해집니다.

var 를 사용하면, 전역변수로 선언이 됩니다

임시 변수 제거하기

임시 변수의 단점 ⇒ 명령형으로 가득한 로직 , 디버깅이 힘들고 유지보수가 어렵다.

해결 방법 : 함수 나누기 , 바로 반환, 고차함수 (map,filter,reduce), 선언형 함수로 변환

function getElement(){
    const result = {}
    result.a = 'a'
    result.b = 'b'
    result.c = 'c'
    return result 
}

result 라는 변수를 만들어서 return 하고 있지만 , 임시 변수를 최대한 줄이는 것이 좋습니다.

function getElement(){
     return { a:'a',b:'b',c:'c'}
}

호이스팅

호이스팅 : 런타임시 선언을 최상단으로 끌어올려 주는 것을 뜻합니다.

문제 : 코드를 작성할 때 예측하지 못하는 것이 실행되기도 합니다.

  • var 를 이용하면 선언을 하기 전에 데이터를 할당하기 때문에 undefined가 나올 수 있습니다.

방법 : var 을 안쓰고 , 함수를 함수 표현식으로 사용하면 오류를 줄일 수 있습니다.

'JavaScript' 카테고리의 다른 글

모듈 번들러  (0) 2022.09.07
Babel 사용법  (0) 2022.09.07
클린코드 작성하기 - 2  (0) 2022.08.31
JavaScript 주석달기  (0) 2022.08.26

+ Recent posts