TypeScript

TypeScript 문법

눙엉 2021. 11. 6. 18:10
이 글은 코딩앙마님의 유튜브를 보고 정리한 내용입니다.

문자

let car:string = 'bmw';

숫자

let age:number = 30;

boolean

let isAdult:boolean = true;

배열

배열에 정해진 타입만 추가할 수 있다.

let a:number[] = [1,2,3];
let a2:Array<number> = [1,2,3];

let week1:string[] = ['mon', 'tue', 'wed'];
let wekk2:Array<string> = ['mon', 'tue', 'wed'];

튜플 (Tuple)

배열과 비슷한 형태이지만 인덱스별로 타입이 다를 때 사용하면 된다.

0번 인덱스와 1번 인덱스는 타입이 달라서 사용할 수 있는 메서드도 다르다.

ex: b[0].toLowerCase() 는 가능하지만 b[1]에서는 사용할 수 없다.

let b:[string, number];
b = ['z', 1];
// b = [1, 'z'] 불가능

void, never

sayHello같이 함수가 아무 것도 반환하지 않을 때 void 타입을 사용한다. 

error를 반환하거나 끝나지 않는 함수를 사용할 때 never 타입을 사용한다.

function sayHello():void{
	console.log('hello');
}

function showError():never{
	throw new Error();
}

function infLoop():never{
	while (true) {
    	// do something...
    }
}

enum

비슷한 값들 끼리 모아 둔 것이라고 생각하면 된다.

Window부터 0이라는 값이 순차적으로 할당되게 된다.

만약 Ios에 4라는 값을 할당하게 되면 Android는 5를 할당하게 된다.

enum Os {
	Window,
    Ios,
    Android
}

enum은 양방향 랩핑이어서 console.log(Os[1])을 하게 되면 Ios가 출력되게 된다. 반대로 console.log(Os['Ios'])를 하게 되면 10이 출력되게 된다.

enum Os {
	Window = 'win',
    Ios = 'ios',
    Android = 'and'
}

let myOs:Os;

myOs = Os.Window

enum은 특정 값만 입력할 수 있도록 하고 싶을 때 사용하면 된다.


null, undefined

let a:null = null;
let b:nudefined = undefined;

object

let user:object;

interface

type Score = 'A' | 'B' | 'C' | 'F';

interface User {
	name: string;
    age: number;
    gender? : string; // gender는 있어도 되고 없어도되는 옵션이다.
    readonly birthYear : number; // 읽기 전용 속석으로 수정이 불가능하다.
    [grade:number] : string; // number를 키로 사용하고 string을 값으로 받는 프로퍼티를 여러 개 사용할 수 있다.
	[grade:number] : Score; // 값으로 Score에 있는 문자열만 사용할 수 있다.
}

let user : User = {
	name : 'suhyeok',
    age : 27
    birthyear: 1996
}

user.age = 28;

// 숫자를 더하는 함수
interface Add {
	(num1:number, num2:number): number;
}

const add : Add = function(x, y){
	return x + y;
}

add(10, 20);

// 나이를 입력받아 성인인지 판단하는 함수
interface IsAdult {
	(age:number):boolean;
}

const a:IsAdult = (age) => {
	return age > 19;
}

a(27) // true

//implements
interface Car {
	color: string;
    wheels: number;
    start(): void;
}

class BMW implements Car {
	color;
    wheels = 4;
    constructor(c:string){
    	this.color = c;
    }
    start(){
    	console.log('go...');
    }
}

const b = new BMW('blue');

// extends
interface BENZ extends Car {
	door: number;
   	stop(): void;
}

const benz : BENZ = {
	color: 'black',
    wheels: 4,
	door : 5,
    start(){
    	console.log('go...');
    },
    stop(){
    	console.log('stop...');
    }
}

함수

function add(num1: number, num2: number): number{
	return num1 + num2;
}

function hello(name?: string) {
	//name은 없어도 되지만 사용할 땐 undefined이거나  string으로 사용해야 한다.
	return `Hello, ${name || 'world'}`;
}

const result = hello();

function hello(name: string, age?: number): string {
// 옵셔널한 값이 무조건 뒤에 있어야 한다. 
	if (age !== undefined) {
    	return `Hello, ${name}. You are ${age}.`;
    } else {
    	return `Hello, ${name}`;
    }
}


function add(...nums: number[]) {
// 나머지 매개변수
	return nums.reduce((result, num) => result + num, 0);
}

add(1, 2, 3);