조건문 은 주어진 조건식의 평가 결과에 따라 코드 블럭의 실행을 결정한다. 조건식은 Boolean값으로 평가될 수 있는 표현식이다.
if
문은 if (조건) {내용}
으로 구성되며, 지정한 조건이 참(true)인 경우 명령문(statement)을 실행한다.
if
문의 구성if (조건식) { // 조건식이 참이면 이 코드 블록이 실행된다. } else { // 조건식이 거짓이면 이 코드 블록이 실행된다. }
▼ if문은 중첩시켜서 사용할 수 있다.
if
문의 중첩if(조건식1) { // 조건식1이 참이면 이 코드 블록이 실행된다. if(조건식2) { // 조건식2가 참이면 이 코드 블록이 실행된다. } else { // 조건식2가 거짓이면 이 코드 블록이 실행된다. } } else { // 조건식1이 거짓이면 이 코드 블록이 실행된다. }
▼ 조건을 여러개로 하고 싶으면 else if 문을 사용하여 조건을 구체화할 수 있으며 else if 문과 else 문은 옵션으로 사용할 수도 있고 사용하지 않을 수도 있다.
조건을 구체화 하기
if (조건식1) { // 조건식1이 참이면 이 코드 블록이 실행된다. } else if (조건식2) { // 조건식2이 참이면 이 코드 블록이 실행된다. } else { // 조건식1과 조건식2가 모두 거짓이면 이 코드 블록이 실행된다. }
▼ 대부분의 if…else 문은 삼항 조건 연산자로 바꿔쓸 수 있다.
간단한 if...else문 삼항 연산자로 바꾸기
// x가 짝수이면 ‘짝수'를 홀수이면 ‘홀수'를 반환한다. var x = 2; var result; // if (x % 2) { // 2 % 2는 0이고 0은 false로 취급된다. result = '홀수'; } else { result = '짝수'; } console.log(result); // 짝수 // x가 짝수이면 '짝수'를 홀수이면 '홀수'를 반환한다. var x = 2; var result = x % 2 ? '홀수' : '짝수'; // 0은 false로 취급된다. console.log(result); // 짝수
▼ ❓ 만약 세가지 경우의 수를 둔다면 이와 같이 작성할 수 있다.
var num = 2; // 0은 false로 취급된다. var kind = num ? (num > 0 ? '양수' : '음수') : '영'; console.log(kind); // 양수
❗️✍️ alert
, ===, &&
을 이용해서 if...else
조건문 연습해보기! ▼
<!DOCTYPE html>
<html lang="ko">
<head>
<meta charset="UTF-8">
<title>seul'p</title>
</head>
<body>
<script>
(1)
let id = prompt("아이디를 입력해 주세요");
if ( id === "seul"){
let password = prompt("비밀번호를 입력해 주세요");
if (password === "1111"){
//alert("환영합니다 " + id + " 님 :)"); 대신 백틱기호를 사용!
alert(`환영합니다 ${id} 님:D!!`)
}
else {
alert("비밀번호를 다시 확인해주세요");
}
}
else {
alert("아이디를 다시 확인해주세요");
}
(2)
let id = prompt('아이디를 입력해주세요');
let passward = prompt('비밀번호를 입력해주세요');
if (id === 'seul' && passward === '1111') {
alert('환영합니다!')
}
else {
alert('다시 확인해 주세요')
}
</script>
</body>
</html>
📌 Check !
alert("환영합니다 " + id + " 님 :)");
대신 백틱기호를 사용해서 표현해 봤다!
(1)과 (2)가 완벽히 서로 일치하는 표현은 아니다. (1)의 경우 아이디가 참일 경우 비밀번호가 거짓이라면 비밀번호를 확인해 달라는 메세지가 나오게 했다.
switch 문은 논리적 참, 거짓보다는 다양한 상황(case)에 따라 실행할 코드 블록을 결정할 때 사용한다.
switch 문은 switch 문의 표현식을 평가하여 그 값과 일치하는 표현식을 갖는 case 문으로 실행 순서를 이동시킨다.
case 문은 상황(case)을 의미하는 표현식을 지정하고 콜론으로 마친다. 그리고 그 뒤에 실행할 문들을 위치시킨다.
switch 문의 표현식과 일치하는 표현식을 갖는 case 문이 없다면 실행 순서는 default 문으로 이동한다. default 옵션으로 사용할 수도 있고 사용하지 않을 수도 있다.
switch
문의 구성switch (표현식) { case 표현식1: switch 문의 표현식과 표현식1이 일치하면 실행될 문; break; case 표현식2: switch 문의 표현식과 표현식2가 일치하면 실행될 문; break; default: switch 문의 표현식과 일치하는 표현식을 갖는 case 문이 없을 때 실행될 문; }
❗️✍️ switch
문 만들어보기! ▼
// 'switch' 안에있는 이 값(browser)이 'IE'면 case 'IE' : 를 실행해라 ▼
const browser = 'IE';
switch (browser) {
case 'IE':
console.log('go away!');
break;
case 'chrome':
case 'Firefox':
console.log('okok!');
break;
default:
console.log('hello!');
}
📌 Check !
주의할 점은 case하나마다 내용 밑에 break;
을 적어줘야 한다는 것! break을 적지 않으면 해당 case 아래로 모든 내용이 실행되어 마지막 defalt 값이 나올 것이다. (default 문은 switch 문의 가장 마지막에 위치하므로 별도로 break 문을 생략해도 된다.)
'case' 를 연달아서(붙여서) 중복사용 하면 자동적으로 묶여서 출력이 가능하다.
switch문은 다양한 키워드로 인해 복잡해질 수 있는 문법 때문에 if...else문으로도 충분이 해결이 된다면 if...else를 사용하는 편이 좋지만,
반대로 if문에서 if...else 여러개를 섞어서 쓸 경우엔 switch 를 고려해보고, 가독성을 더 좋게 만드는 방법도 있다고 한다. 😀
reference
MDN-if...else MDN-swtich Coding Everybody poiemaweb