지난시간은 왜써야하는지에 알아봤으니 이제 본격적으로 Typescript에 기본타입에 대해 한번 알아보자.
우선 가장 처음으로는 컴파일 실행법으로는
이런식으로 컴파일을 해주면된다. 생각보다 간단하다.
우선 데이터 타입에 대해 다시 한번 돌아본다면,
const num: number = 1;
string
const str: string = "hello";
boolean
const boole: boolean = true;
undefined - 값이 있는지 없는지 아직 결정되있지 않은상태,
let undef: undefined;
undef = "hello"; *// error 발생, 따라서 혼자쓰지않는다*
// 이런식으로 사용이 가능하다.
let phoneNum: number | undefined;
phoneNum = undefined;
phoneNum = 12;
null - 값이 텅텅 비었다 라는것이 정해진상태
let person: null; *//person에는 null만 할당할수있게된다.
let poerson2: string | null;*
unknown - 어떤 데이터 타입이 올지 모르는 상태 (비추천)*
let notSure: unknown = 0;
notSure = "nice";
notSure = true;
any - 어떤 데이터 타입이 올지 모르는 상태 (비추천)*
let anything: any = 0;
anything = "hello";
void - 아무런것도 리턴하지 않을때, return이 생략되어졌을때
function print(): void {
console.log("heelo"); //출력
//return 생략
}
let unusable: void = undefined; // undefined만 선언가능
never - 리턴할 계획이 없을때, 리턴할수없다.
다시말하면 never 타입은 절대로 발생하지 않는 값의 타입을 나타낸다. Ex) never는 함수표 현식의 리턴 타입, 항상 예외를 던지는 화살표 함수 표현식, 리턴하지 않는 표현식같은 것들.
function throwError(message: string): never {
//message => server(log)
throw new Error(message);
while (true) {}
}
object - 어떠한 object도 전달이 가능하다 원시타입을 제외한 모든 배열도가능
let obj: object;
function acceptSomeObject(obj: object) {}
acceptSomeObject({ name: "ellie" });
acceptSomeObject({ animal: "dog" });
//js
function jsAdd(num1, num2) {
return num1 + num2;
}
//ts
function add(num1: number, num2: number): number {
return num1 + num2;
}
//js
function jsFetchNum(id) {
// code...
// code...
// code...
return new Promise((resolve, reject) => {
resolve(100);
});
}
//ts
// fetchNum 이 숫자를 fetch하는 함수고 인자로 string을받아, promise를 리턴하고 promise는 숫자의 데이터를 리턴한다라는것을 쉽게 알수있게된다.
function fetchNum(id: string): Promise<number> {
// code...
// code...
// code...
return new Promise((resolve, reject) => {
resolve(100);
});
}
}