제어문
제어문은 조건에 따라 코드 블록을 실행(조건문)하거나 반복 실행(반복문)할 때 사용한다.
일반적으로 코드는 위에서 아래 방향으로 순차적으로 실행되는데
제어문을 사용하면 코드의 실행 흐름을 인위적으로 제어할 수 있다.
블록 문{} 은 0개 이상의 문을 중괄호로 묶은 것으로, 코드 블록 또는 블록이라고 부르기도 한다.
자바스크립트는 블록 문을 하나의 실행 단위로 취급한다.
블록 문은 단독으로 사용할 수도 있으나 일반적으로 제어문이나 함수를 정의할 때 사용하는 것이 일반적이다.
또한 블록문은 자체 종결 성을 갖기 때문에 블록 문의 끝에는 세미콜론을 붙이지 않는다.
조건문
조건문은 주어진 조건식의 평가 결과에 따라 코드블록(블록문)의 실행을 결정한다.
조건식은 불리언 값으로 평가될 수 있는 표현식이다.
if ...else 문
if... else 문은 주어진 조건식의 평가 결과 논리적 참 또는 거짓에 따라 실행할 코드 블록을 결정한다.
if문의 조건식은 불리언 값으로 평가되어야 한다. 만약 if 문의 조건식이 불리언 값이 아닌 값으로 평가되면
자바스크립트 엔진에 의해 암묵적으로 불리언 값으로 강제 변환되어 실행할 코드 블록을 결정한다.
else if 문과 else 문은 사용할 수도 사용하지 않을 수도 있다.
if문과 else문은 2번 이상 사용할 수 없지만 else if 문은 여러 번 사용할 수 있다.
또한 if ...else 문은 삼항 조건 연산자로 바꿔 쓸 수 있다.
switch 문
switch문은 주어진 표현식을 평가하여 그 값과 일치하는 표현식을 갖는 case 문으로 실행 흐름을 옮긴다.
case 문은 상황을 의미하는 표현식을 지정하고 콜론으로 마친다.
switch 문의 표현식과 일치하는 case 문이 없다면 실행 순서는 default 문으로 이동하게 된다.
if... else문은 불리언 값으로 평가되어야 하지만 switch 문의 표현식은 불리언 값보다는 문자열이나 숫자 값인 경우가 많다.
따라서 if ...else문은 논리적 참, 거짓으로 실행할 코드 블록을 결정하지만
switch문은 다양한 case에 따라 실행할 코드 블록을 결정할 때 사용한다.
반복문
반복문은 조건식의 평가 결과가 참인 경우 코드 블록을 실행한다.
그 후 조건식을 다시 평가하여 여전히 참인 경우 코드 블록을 다시 실행한다.
이는 조건식이 거짓일 때까지 반복된다.
for 문
for 문은 조건식이 거짓으로 평가될 때 까지 코드 블록을 반복 실행한다.
for 문의 변수 선언문, 조건식, 증감식은 모두 옵션이므로 반드시 사용할 필요는 없지만
어떤 식도 선언하지 않으면 무한루프가 된다.
for문 내에 for문을 중첩해 사용할 수 있으며 이를 중첩 for 문이라 한다.
while 문
while 문은 주어진 조건식의 평가 결과가 참이면 코드 블록을 계속해서 반복 실행한다.
for 문은 반복횟수가 명확할 때 주로 사용하고 while 문은 반복 횟수가 불명확할 때 주로 사용한다.
while 문은 조건식의 평가 결과가 거짓이 되면 코드 블록을 실행하지 않고 종료한다.
만약 조건식의 평가 결과가 불리언 값이 아니면 불리언 값으로 강제 변환하여 논리적 참, 거짓을 구별한다.
do... while 문
do... while 문은 코드 블록을 먼저 실행하고 조건식을 평가한다. 따라서 코드 블록은 무조건 한 번 이상 실행된다.
break 문
break 문은 코드 블록을 탈출한다. 정확히 표현하자면 코드 블록을 탈출하는 것이 아니라 레이블 문, 반복문 또는 switch 문의 코드 블록을 탈출한다.
레이블 문이란 식별자가 붙은 문을 말한다.
//레이블 문
if(true) {
break;
}
switch 문의 case 문과 default 문도 레이블 문이다.
레이블 문을 탈출하려면 break 문에 레이블 식별자를 지정한다.
continue
continue 문은 반복문의 코드 블록 실행을 현 지점에서 중단하고 반복문의 증감식으로 실행 흐름을 이동시킨다.
break 문처럼 반복문을 탈출하지는 않는다.
오늘은 어제와 마찬가지로 토이 프로젝트를 진행하였습니다.
Axios는 확실히 처음 사용해봐서 익숙지 않았습니다!
또 리덕스 툴킷을 사용하여 리덕스를 작성했는데
확실히 덕스구조에 비해 편리했지만 리덕스 툴킷도 손에 익숙지 않아 어려웠습니다!
앞으로도 어려움을 자주 맞이하겠지만 어려움을 하나씩 하나씩 이겨내어
좋은 개발자가 되기위해 노력할 것입니다!!
다들 파이팅!!
👍👍👍✍️✍️✍️
'자바스크립트' 카테고리의 다른 글
TIL] 객체 (0) | 2021.07.17 |
---|---|
TIL] 타입변환과 단축 평가 (0) | 2021.07.15 |
TIL] 연산자 (0) | 2021.07.14 |
TIL] 데이터 타입 (0) | 2021.07.13 |
TIL] 표현식과 문 (0) | 2021.07.12 |