You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Web-Dev-For-Beginners/translations/ko/2-js-basics/3-making-decisions/README.md

9.7 KiB

JavaScript 기초: 의사결정

JavaScript Basics - Making decisions

스케치노트: Tomomi Imura

강의 전 퀴즈

강의 전 퀴즈

코드 실행 순서를 제어하고 결정을 내리는 것은 코드를 재사용 가능하고 견고하게 만듭니다. 이 섹션에서는 JavaScript에서 데이터 흐름을 제어하는 구문과 Boolean 데이터 타입과 함께 사용할 때의 중요성을 다룹니다.

Making Decisions

🎥 위 이미지를 클릭하면 의사결정에 대한 영상을 볼 수 있습니다.

이 강의를 Microsoft Learn에서 수강할 수 있습니다!

Boolean에 대한 간단한 복습

Boolean은 true 또는 false 두 가지 값만 가질 수 있습니다. Boolean은 특정 조건이 충족될 때 실행할 코드 라인을 결정하는 데 도움을 줍니다.

Boolean 값을 설정하려면 다음과 같이 작성합니다:

let myTrueBool = true
let myFalseBool = false

Boolean은 영국의 수학자, 철학자, 논리학자인 George Boole(18151864)의 이름을 따서 명명되었습니다.

비교 연산자와 Boolean

연산자는 조건을 평가하고 Boolean 값을 생성하기 위해 비교를 수행하는 데 사용됩니다. 아래는 자주 사용되는 연산자의 목록입니다.

기호 설명 예제
< 작다: 두 값을 비교하여 왼쪽 값이 오른쪽 값보다 작으면 true Boolean 값을 반환합니다. 5 < 6 // true
<= 작거나 같다: 두 값을 비교하여 왼쪽 값이 오른쪽 값보다 작거나 같으면 true Boolean 값을 반환합니다. 5 <= 6 // true
> 크다: 두 값을 비교하여 왼쪽 값이 오른쪽 값보다 크면 true Boolean 값을 반환합니다. 5 > 6 // false
>= 크거나 같다: 두 값을 비교하여 왼쪽 값이 오른쪽 값보다 크거나 같으면 true Boolean 값을 반환합니다. 5 >= 6 // false
=== 엄격한 동등성: 두 값을 비교하여 값과 데이터 타입이 모두 같으면 true Boolean 값을 반환합니다. 5 === 6 // false
!== 불일치: 두 값을 비교하여 엄격한 동등성 연산자가 반환하는 값의 반대 Boolean 값을 반환합니다. 5 !== 6 // true

브라우저의 콘솔에서 몇 가지 비교를 작성하여 지식을 확인해 보세요. 반환된 데이터 중 놀라운 것이 있나요?

If 문

If 문은 조건이 true일 때 블록 안의 코드를 실행합니다.

if (condition) {
  //Condition is true. Code in this block will run.
}

논리 연산자는 종종 조건을 구성하는 데 사용됩니다.

let currentMoney;
let laptopPrice;

if (currentMoney >= laptopPrice) {
  //Condition is true. Code in this block will run.
  console.log("Getting a new laptop!");
}

If..Else 문

else 문은 조건이 false일 때 블록 안의 코드를 실행합니다. 이는 if 문과 함께 선택적으로 사용할 수 있습니다.

let currentMoney;
let laptopPrice;

if (currentMoney >= laptopPrice) {
  //Condition is true. Code in this block will run.
  console.log("Getting a new laptop!");
} else {
  //Condition is false. Code in this block will run.
  console.log("Can't afford a new laptop, yet!");
}

브라우저 콘솔에서 이 코드와 아래 코드를 실행하여 이해도를 테스트해 보세요. currentMoneylaptopPrice 변수의 값을 변경하여 반환되는 console.log()를 확인해 보세요.

Switch 문

switch 문은 다양한 조건에 따라 다른 동작을 수행하는 데 사용됩니다. switch 문을 사용하여 실행할 여러 코드 블록 중 하나를 선택할 수 있습니다.

switch (expression) {
  case x:
    // code block
    break;
  case y:
    // code block
    break;
  default:
  // code block
}
// program using switch statement
let a = 2;

switch (a) {
  case 1:
    a = "one";
    break;
  case 2:
    a = "two";
    break;
  default:
    a = "not found";
    break;
}
console.log(`The value is ${a}`);

브라우저 콘솔에서 이 코드와 아래 코드를 실행하여 이해도를 테스트해 보세요. 변수 a의 값을 변경하여 반환되는 console.log()를 확인해 보세요.

논리 연산자와 Boolean

결정은 여러 비교를 필요로 할 수 있으며, 논리 연산자를 사용하여 Boolean 값을 생성할 수 있습니다.

기호 설명 예제
&& 논리 AND: 두 Boolean 표현식을 비교합니다. 양쪽 모두 true일 때만 true를 반환합니다. (5 > 6) && (5 < 6 ) // 한쪽은 false, 다른 쪽은 true. false 반환
|| 논리 OR: 두 Boolean 표현식을 비교합니다. 한쪽이라도 true일 경우 true를 반환합니다. (5 > 6) || (5 < 6) // 한쪽은 false, 다른 쪽은 true. true 반환
! 논리 NOT: Boolean 표현식의 반대 값을 반환합니다. !(5 > 6) // 5는 6보다 크지 않지만 "!"는 true를 반환

논리 연산자를 사용한 조건과 결정

논리 연산자는 if..else 문에서 조건을 구성하는 데 사용할 수 있습니다.

let currentMoney;
let laptopPrice;
let laptopDiscountPrice = laptopPrice - laptopPrice * 0.2; //Laptop price at 20 percent off

if (currentMoney >= laptopPrice || currentMoney >= laptopDiscountPrice) {
  //Condition is true. Code in this block will run.
  console.log("Getting a new laptop!");
} else {
  //Condition is true. Code in this block will run.
  console.log("Can't afford a new laptop, yet!");
}

부정 연산자

지금까지 if...else 문을 사용하여 조건부 논리를 만드는 방법을 살펴보았습니다. if 안에 들어가는 모든 것은 true/false로 평가되어야 합니다. ! 연산자를 사용하면 표현식을 부정 할 수 있습니다. 다음과 같이 보일 것입니다:

if (!condition) {
  // runs if condition is false
} else {
  // runs if condition is true
}

삼항 표현식

if...else는 결정 논리를 표현하는 유일한 방법이 아닙니다. 삼항 연산자라고 불리는 것을 사용할 수도 있습니다. 그 구문은 다음과 같습니다:

let variable = condition ? <return this if true> : <return this if false>

아래는 더 구체적인 예제입니다:

let firstNumber = 20;
let secondNumber = 10;
let biggestNumber = firstNumber > secondNumber ? firstNumber : secondNumber;

이 코드를 몇 번 읽어보세요. 이 연산자들이 어떻게 작동하는지 이해가 되나요?

위 코드는 다음을 의미합니다:

  • firstNumbersecondNumber보다 크다면
  • firstNumberbiggestNumber에 할당합니다.
  • 그렇지 않으면 secondNumber를 할당합니다.

삼항 표현식은 아래 코드를 간단하게 작성한 방식입니다:

let biggestNumber;
if (firstNumber > secondNumber) {
  biggestNumber = firstNumber;
} else {
  biggestNumber = secondNumber;
}

🚀 도전 과제

논리 연산자를 사용하여 프로그램을 작성한 후, 이를 삼항 표현식을 사용하여 다시 작성해 보세요. 어떤 구문이 더 선호되나요?


강의 후 퀴즈

강의 후 퀴즈

복습 및 자기 학습

사용자가 사용할 수 있는 다양한 연산자에 대해 더 알아보려면 MDN을 참조하세요.

Josh Comeau의 훌륭한 연산자 조회를 살펴보세요!

과제

연산자


면책 조항:
이 문서는 AI 번역 서비스 Co-op Translator를 사용하여 번역되었습니다. 정확성을 위해 최선을 다하고 있지만, 자동 번역에는 오류나 부정확성이 포함될 수 있습니다. 원본 문서의 원어 버전을 신뢰할 수 있는 권위 있는 자료로 간주해야 합니다. 중요한 정보의 경우, 전문적인 인간 번역을 권장합니다. 이 번역 사용으로 인해 발생하는 오해나 잘못된 해석에 대해 책임을 지지 않습니다.