[JavaScript] 모던 자바스크립트 Deep Dive로 배우는 JS #8 제어문(1)

ChilihC·2022년 8월 29일
0
post-thumbnail

TIL(Today I Learned) 🧑🏻‍💻


8. 제어문(1)


  • 제어문(control flow statement)는 조건에 따라 코드 블록을 실행(조건문)하거나 반복 실행(반복문)할 때 사용한다.

  • 제어문을 사용하면 코드의 실행 흐름을 인위적으로 제어할 수 있다.

  • 코드의 실행 순서가 변경된다는 것은 단순히 위에서 아래로 순차적으로 진행하는 직관적인 코드의 흐름을 혼란스럽게 만든다.

  • 제어문은 코드의 흐름을 이해하기 어렵게 만들어 가독성을 해치는 단점이 있다.

  • forEach, map, filter, reduce 같은 고차 함수를 사용한 함수형 프로그래밍 기법에서는 제어문의 사용을 억제하여 복잡성을 해결하려고 노력한다.

8.1  블록문

  • 블록문(block statement/compound statement)은 0개 이상의 문을 중괄호로 묶은 것으로, 코듭 블록 또는 블록이라고 부르기도 한다.
    ( 자바스크립트는 블록문을 하나의 실행 단위로 취급한다. )

  • 블록문은 언제나 문의 종료를 의미하는 자체 종결성을 갖기 때문에 블록문의 끝에는 세미클론을 붙이지 않는다는 것에 주의하자.


8.2  조건문

  • 조건문(conditional statement)은 주어진 조건식(conditional expression)의 평가 결과에 따라 코드 블록(블록문)의 실행을 결정한다. 조건식은 불리언 값으로 평가될 수 있는 문이다.

  • 자바스크립트는 if ... else문과 switch문으로 두 가지 조건문을 제공한다.


8.2.1  if ... else 문

  • if ... else 문은 주어진 조건식(불리언 값으로 평가될 수 있는 표현식)의 평가 결과, 즉 논리적 참 또는 거짓에 따라 실행할 코드 블록을 결정한다.
if (조건식) {
  // 조건식이 참이면 이 코드 블록이 실행된다.
} else {
  // 조건식이 거짓이면 이 코드 블록이 실행된다. 
}
  • 만약 if 문의 조건식이 불리언 값이 아닌 값으로 평가되면 자바스크립트 엔진에 의해 암묵적으로 불리언 값으로 강제 변환된다.

  • 조건식을 추가하여 조건에 따라 실행될 코드 블록을 늘리고 싶으면 else if 문을 사용한다.

if (조건식1) {
  // 조건식1이 참이면 이 코드 블록이 실행된다.
} else if (조건식2) {
  // 조건식2이 참이면 이 코드 블록이 실행된다. 
} else {
  // 조건식1과 조건식2가 모두 거짓이면 이 코드 블록이 실행된다. 
}
  • 만약 코드 블록 내의 문이 하나뿐이라면 중괄호를 생략할 수 있다.

  • 대부분의 if ... else 문은 삼항 조건 연산자로 바꿔 쓸 수 있다.

  • 조건에 따라 단순히 값을 결정하여 변수에 할당하는 경우 if ... else 문보다 삼항 조건 연산자를 사용하는 편이 가독성이 좋다.

  • 조건에 따라 실행해야 할 내용이 복잡하여 여러 줄의 문이 필요하다면 if ... else 문을 사용하는 편이 가독성이 좋다.


8.2.2  switch 문

  • switch 문은 주어진 표현식을 평가하여 그 값과 일치하는 표현식을 갖는 case 문으로 실행 흐름을 옮긴다.

  • switch 문의 표현식과 일치하는 case 문이 없다면 실행 순서는 default 문으로 이동한다. default 문은 선택사항으로, 사용할 수도 있고 사용하지 않을 수도 있다.

switch (표현식) {
  case 표현식1:
    // switch 문의 표현식과 표현식1이 일치하면 실행될 문;
    break;
  case 표현식2:
    // switch 문의 표현식과 표현식2가 일치하면 실행될 문;
  	break;
  default:
    // switch 표현식과 일치하는 case 문이 없을 때 실행될 문;
}
  • if ... else 문은 논리적 참, 거짓으로 실행할 코드 블록을 결정한다.

  • switch 문은 논리적 참, 거짓보다는 다양한 상황(case)에 따라 실행할 코드 블록을 결정한다.

  • break 문이 없다면 case 문의 표현식과 일치하지 않더라도 실행 흐름이 다음 case 문으로 연이어 이동한다. 이를 폴스루(fall through) 라고 부른다.

  • default 문에는 break 문을 생략하는 것이 일반적이다. (default 문이 switch 문의 맨 마지막에 위치하므로 default 문 종료시 switch 문을 빠져나간다.)

  • break 문을 생략한 폴스루가 유용한 경우도 있다.

  • 폴스루를 활용하면 여러 개의 case문을 하나의 조건으로 사용할 수 있다.


새로운 용어 정리



참고 문헌


* 모던 자바스크립트 Deep Dive ( 자바스크립트의 기본 개념과 동작 원리 ) / 이웅모 지음

profile
developer junior

0개의 댓글