제어문(control flow statement)는 조건에 따라 코드 블록을 실행(조건문)하거나 반복 실행(반복문)할 때 사용한다.
제어문을 사용하면 코드의 실행 흐름을 인위적으로 제어할 수 있다.
코드의 실행 순서가 변경된다는 것은 단순히 위에서 아래로 순차적으로 진행하는 직관적인 코드의 흐름을 혼란스럽게 만든다.
제어문은 코드의 흐름을 이해하기 어렵게 만들어 가독성을 해치는 단점이 있다.
forEach
, map
, filter
, reduce
같은 고차 함수를 사용한 함수형 프로그래밍 기법에서는 제어문의 사용을 억제하여 복잡성을 해결하려고 노력한다.
블록문(block statement/compound statement)은 0개 이상의 문을 중괄호로 묶은 것으로, 코듭 블록 또는 블록이라고 부르기도 한다.
( 자바스크립트는 블록문을 하나의 실행 단위로 취급한다. )
블록문은 언제나 문의 종료를 의미하는 자체 종결성을 갖기 때문에 블록문의 끝에는 세미클론을 붙이지 않는다는 것에 주의하자.
조건문(conditional statement)은 주어진 조건식(conditional expression)의 평가 결과에 따라 코드 블록(블록문)의 실행을 결정한다. 조건식은 불리언 값으로 평가될 수 있는 문이다.
자바스크립트는 if ... else
문과 switch
문으로 두 가지 조건문을 제공한다.
if ... else
문은 주어진 조건식(불리언 값으로 평가될 수 있는 표현식)의 평가 결과, 즉 논리적 참 또는 거짓에 따라 실행할 코드 블록을 결정한다. if (조건식) {
// 조건식이 참이면 이 코드 블록이 실행된다.
} else {
// 조건식이 거짓이면 이 코드 블록이 실행된다.
}
만약 if
문의 조건식이 불리언 값이 아닌 값으로 평가되면 자바스크립트 엔진에 의해 암묵적으로 불리언 값으로 강제 변환된다.
조건식을 추가하여 조건에 따라 실행될 코드 블록을 늘리고 싶으면 else if
문을 사용한다.
if (조건식1) {
// 조건식1이 참이면 이 코드 블록이 실행된다.
} else if (조건식2) {
// 조건식2이 참이면 이 코드 블록이 실행된다.
} else {
// 조건식1과 조건식2가 모두 거짓이면 이 코드 블록이 실행된다.
}
만약 코드 블록 내의 문이 하나뿐이라면 중괄호를 생략할 수 있다.
대부분의 if ... else
문은 삼항 조건 연산자로 바꿔 쓸 수 있다.
조건에 따라 단순히 값을 결정하여 변수에 할당하는 경우 if ... else
문보다 삼항 조건 연산자를 사용하는 편이 가독성이 좋다.
조건에 따라 실행해야 할 내용이 복잡하여 여러 줄의 문이 필요하다면 if ... else
문을 사용하는 편이 가독성이 좋다.
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 ( 자바스크립트의 기본 개념과 동작 원리 ) / 이웅모 지음