씨네
공부하는 개발자 강씨네
씨네
  • 분류 전체보기 (460)
    • Web (21)
      • HTML (11)
      • CSS (10)
    • JS 관련 (49)
      • JavaScript (27)
      • JQuery (22)
    • TS 관련 (15)
      • TypeScript (15)
    • NodeJS (7)
      • NodeJS (7)
    • 따라하며 배우는 시리즈 (23)
      • NodeJS & ReactJS Basic (23)
      • NodeJS & ReactJS Movie (0)
      • NodeJS & ReactJS Youtube (0)
      • NodeJS & ReactJS ChatBot (0)
    • SPA (14)
      • React (14)
      • Vue (0)
      • Anguler (0)
    • Java 관련 (118)
      • Java (52)
      • JDBC (6)
      • JSP & Servlet (18)
      • Spring Legecy (38)
      • SpringBoot (4)
    • Python (26)
      • Python (20)
      • PyMongo (1)
      • Django (5)
    • Git (24)
      • Github (24)
    • RDB (22)
      • Oracle (21)
      • MySQL (1)
    • NoSQL (5)
      • MongoDB (5)
    • OS (4)
      • Linux (4)
    • 빅데이터 (2)
      • hadoop (2)
    • IDE (20)
      • eclipse (11)
      • VSCODE (4)
      • VisualStudio (1)
      • IntelliJ (1)
      • PyCharm (1)
      • DBeaver (2)
    • Install (3)
      • Tomcat (1)
      • Docker (1)
      • Anaconda (1)
    • 오류&에러 (28)
      • TS (2)
      • NodeJS (7)
      • SQL (8)
      • Java (1)
      • Spring (4)
      • Git (6)
      • 기타 (0)
    • 알고리즘 (67)
      • 수열 (1)
      • 백준(backjoon) (39)
      • Programmers (27)
    • 자격증 (5)
      • SQLD (5)
    • 기타 (2)
    • IT유튜브로 지식쌓기 (2)

공지사항

인기 글

최근 글

티스토리

250x250
hELLO · Designed By 정상우.
씨네

공부하는 개발자 강씨네

[TypeScript] Union Type(유니언 타입), Type Alias, 타입가드
TS 관련/TypeScript

[TypeScript] Union Type(유니언 타입), Type Alias, 타입가드

2022. 7. 16. 15:05
728x90

타입스크립트는 타입 명시를 위해 사용하지만 any라는 타입도 존재합니다.

any라는 타입은 어떤 타입도 올수 있으며 자바스크립트와 같은 역할을 합니다.

let getData: any = 1;
getData = 'hello';
getData = false;

이러처럼 처음에 number타입의 1을 할당하고 이후에 string이나 boolean을 재할당해도 에러가 발생하지 않습니다.

하지만 타입스크립트는 더 많은 타입 명시를 할수록 장점이 나타나기 때문에 any는 사용을 최소화 해야합니다.

그럼에도 any를 반드시 사용해야 할수도 있는데요.

어떤 타입이 들어올지 예측할수 없는 경우는 타입을 지정할 수 없기 때문에 any를 사용해야합니다.

또한 number타입과 string타입 두가지가 들어올수 있는경우도 있을텐데 이런 경우에는 any보다는 union 타입을 사용해주면 좋습니다!

 

let price: number | string = 10000;
data = '만원';
// data = false; // error

위의 코드의 경우 에러가 발생하지 않습니다.

하지만 data라는 변수에 false라는 boolean 타입을 할당해주고자 하면 에러가 발생하게 됩니다.

 

let totalCoas: numner;
let orderID: number | string;

const calculateTotalCose = (price: number | string, qty: number): void => {

};

const findOrderId = (customer: { costomerId: numner | string, name: string}, 
productId: number | string): number | string => {
    return orderId;
}

이 코드는 매우 복잡하죠?? 

코드를 작성할 때는 같은 코드가 있으면 반복해서 쓰는것 보다는 타입으로 지정하고 재사용하는 것이 좋은데요.

이럴때 Typs Alias를 사용할수 있습니다.

 

type StrOrNum = number | string;
let totalCoas: numner;
let orderID: StrOrNum;

const calculateTotalCose = (price: StrOrNum, qty: number): void => {

};

const findOrderId = (customer: { costomerId: StrOrNum, name: string}, productId: StrOrNum): StrOrNum => {
    return orderId;
}

이러한 것을 TypeAlias 라고 부릅니다.

코드가 읽기도 훨신 좋고 간단해 졌죠??

 

type StrOrNum = number | string;
let itemPrice: numner;

const setItemPrice = (price: StrOrNum): void => {
    itemPrice = price;
};

setItemPrice(50);

위의 코드는 에러가 발생하게 됩니다.

price는 number타입이 올수도 있고 string타입이 올수도 있는데 itemPrice는 number만 올 수 있기 때문이죠.

이럴때는 자바스크립트에 내장이 되어있는 typeof Operator를 사용하면 해결할수 있습니다.

Typeof 연산자와 조건문을 사용함으로서 이러한 문제가 되는 코드를 고치는 것입니다.

 

type StrOrNum = number | string;
let itemPrice: numner;

const setItemPrice = (price: StrOrNum): void => {
    if(typeof price === 'string'){
        itemPrice = 0;
    } else {
        itemPrice = price;
    }
};

setItemPrice(50);

유니온 타입을 사용할때는 이러한 코드 검증을 수행하는 유효성 검사가 필요할 때가 있습니다.

이러한 것을 타입스크립트에서는 타입가드(Type Guard)라고 부릅니다.

728x90

'TS 관련 > TypeScript' 카테고리의 다른 글

[TypeScript] Class와 객체(OOP 프로그래밍)  (0) 2022.07.18
[TypeScript] 옵셔널(optional) ?, 선택적 매개변수  (0) 2022.07.17
[TypeScript] Enum(열거형)과 리터럴 타입  (0) 2022.07.15
[TypeScript] Readonly(읽기전용) 속성  (0) 2022.07.14
[TypeScript] 타입으로 사용되는 인터페이스(Interface)  (0) 2022.07.13
    'TS 관련/TypeScript' 카테고리의 다른 글
    • [TypeScript] Class와 객체(OOP 프로그래밍)
    • [TypeScript] 옵셔널(optional) ?, 선택적 매개변수
    • [TypeScript] Enum(열거형)과 리터럴 타입
    • [TypeScript] Readonly(읽기전용) 속성
    씨네
    씨네
    개발자 씨네가 공부하는 내용을 기록 겸 공유하는 블로그입니다!

    티스토리툴바