자바스크립트 조건문
1. if, else if, else 문
🔹if...else 문
- if 문은 if (조건) {내용} 으로 구성되며, 지정한 조건이 참(true)인 경우 명령문(statement)을 실행한다.
- 조건식의 평가 결과가 true일 경우: if 문 다음의 코드 블록이 실행된다.
false일 경우: else 문 다음의 코드 블록이 실행된다.
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)의 경우 아이디가 참일 경우 비밀번호가 거짓이라면 비밀번호를 확인해 달라는 메세지가 나오게 했다.
2. switch 문
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 를 고려해보고, 가독성을 더 좋게 만드는 방법도 있다고 한다. 😀