JavaScript 조건문

seul_velog·2021년 11월 30일
0

JavaScript

목록 보기
6/25
post-thumbnail
post-custom-banner

조건문(conditional statement)

조건문 은 주어진 조건식의 평가 결과에 따라 코드 블럭의 실행을 결정한다. 조건식은 Boolean값으로 평가될 수 있는 표현식이다.



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 를 고려해보고, 가독성을 더 좋게 만드는 방법도 있다고 한다. 😀




reference
MDN-if...else MDN-swtich Coding Everybody poiemaweb

profile
기억보단 기록을 ✨
post-custom-banner

0개의 댓글