06장 데이터 타입

soonmac·2022년 1월 5일
0
post-thumbnail

6. 데이터 타입

데이터 타입의 종류

원시타입

  • 숫자 (number)
  • 문자열 (string)
  • 불리언 (boolean) - true/false
  • undefined
  • null
  • 심벌 (symbol)

객체타입

  • 객체, 함수, 배열 등

6.1 숫자 타입

🍧 숫자 타입: 정수와 실수 구분없이 하나의 숫자 타입만 존재합니다.

숫자 타입은 실수 외에도 세 가지 특별한 값도 표현할 수 있습니다.

  • Infinity : 양의 무한대
console.log(10/0) //Infinity
  • -Infinity : 음의 무한대
console.log(10/-0) //-Infinity
  • Nan : 산술 연산 불가(not a number) ※대소문자 주의
console.log(1 * 'String'); // Nan

6.2 문자열 타입

🍧문자열 타입: 텍스트 데이터를 나타내는데 사용합니다.

  • '', "", `` 으로 텍스트를 감쌉니다. (키워드, 식별자같은 토큰과 구분)

6.3 템플릿 리터럴

🍧템플릿 리터럴: 멀티라인(2줄 이상의) 문자열, 표현식 삽입, 태그드 탬플릿 등 편리한 문자열 처리 기능

6.3.1 멀티라인 문자열

/n(줄바꿈),/t(탭) 등의 이스케이프 시퀀스를 쓰지 않고도 줄바꿈, 공백이 타이핑한 대로 적용됩니다.

var template = `<ul>
	<li><a href="#">HOME</a></li>
<ul>`;

이걸 콘솔로 찍어보면 아래처럼 나옵니다.

<ul>
	<li><a href="#">HOME</a></li>
<ul>

6.3.2 표현식 삽입

var first = "Ung-mo"
var last = "Lee";
console.log(`MY name is ${first} ${last}.`) // My name is Ung-mo Lee.

${ }으로 표현식을 감쌉니다. 평가결과가 문자열이 아니더라도 문자열 타입으로 강제 변환됩니다.

6.5 undefined 타입

🍧undefined : 자바스크립트 엔진이 변수를 초기화할 때 사용하는 값입니다. (암묵적 초기화)

변수에 값이 없다는 것을 명시하고 싶을 때는 null을 씁니다.

6.6 null 타입 (대소문자 주의!)

🍧null : 변수에 값이 없다는 것을 의도적으로 명시합니다.

함수가 유효한 값을 반환할 수 없을 경우 null을 반환하기도 합니다.

<body>
  <script>
      var element = document.querySelector('.myClass');
      console.log(element); //null
  </script>
</body>

6.7 심벌타입

🍧심벌 타입: 다른 값과 중복되지 않는 유일무이한 값. 객체의 유일한 프로퍼티 키를 만들기 위해 사용합니다.

var key = Symbol('key');
// Symbol 함수를 호출해 생성합니다.

6.9 데이터 타입의 필요성

  • 값을 저장할 때 확보해야하는 메모리 공간의 크기를 결정
  • 값을 참조할 때 한 번에 읽어들어야 할 메모리 공간의 크기를 결정
  • 메모리에서 읽어 들인 2진수를 어떻게 해석할지 결정

6.10 동적 타이핑

6.10.1 동적 타입 언어와 정적 타입 언어

🍧정적 타입 언어: 변수 선언 시점에 변수 타입이 결정됩니다. 타입은 바꿀 수 없습니다.

🍧동적 타입 언어: 할당(값)에 의해 타입이 결정됩니다. 재할당(값변경)에 의해 변수의 타입을 자유롭게(동적으로) 바꿀 수 있습니다.

6.10.2 동적 타입 언어와 변수

동적 타입의 단점!

  • 유연성은 높지만 신뢰성은 떨어집니다. 왜냐하면 엔진에 의해 암묵적으로 타입이 자동으로 바뀌는 경우가 많기 때문에 사람 머리 아프게 합니다.

변수를 사용할 때 주의할 사항

  • 변수는 꼭 필요한 경우에
  • 변수의 유효 범위(스코프)는 최대한 좁게
  • 전역 변수는 최대한 사용 금지
  • 변수보다는 상수를 사용해 값의 변경 억제하기
  • 변수 이름은 목적이나 의미를 파악할 수 있도록
profile
공부중

0개의 댓글