[web개발][javascript] TypeScript 기본 문법 정리

1. 기본 TS 타입 선언Permalink

문자열Permalink

 

let str: string = 'hello';

숫자Permalink

 

let num: number = 100;

배열Permalink

 

let arr: Array<number> = [10 , 20, 30];
let arr2: number[] = [10, 20, 30];
let arr3: Array<string> = ["lion", "tiger"];
let arr4: [string, number] = ["sejong", 182];

객체Permalink

 

let obj: object = { name: "yeom", age: 29 };
let person: { name: string, age: number };

BooleanPermalink

 

let isAvaliable: boolean = true;

2. 함수 선언Permalink

 

parameter와 return 값에 대해 타입 선언을 할 수 있다.

function sum(a: number, b: number): number {
  return a + b;
}

optional parameter일 경우 ? 를 사용한다.

function log(time: string, result?: string, option?: string) {
	console.log(time, result, option);
}

log("2021-10-04", "success");

3. 인터페이스(interface)Permalink

 

interface는 자주 사용하는 타입들을 object 형태의 묶음으로 정의해 새로운 타입을 만들어 사용하는 기능이다.

interface 선언Permalink

 

interface User {
  age: number;
  name: string;
}

변수 활용Permalink

 

const yeom: User = { age: 30, name: 'kyeorae'}

함수 인자로의 활용Permalink

 

function getUser(user: User) {
  console.log(user);
}

getUser({ age: 10, name: 'hayoon'});

함수 구조 활용Permalink

 

interface Sum {
  (a: number, b: number): number;
}

let sumFunc: Sum: 
sumFunc = function(a: number, b: number): number {
  return a + b;
}

배열 활용Permalink

 

interface StringArray {
  [index: number]: string;
}

let arr: StringArray = ['a', 'b', c];

객체 활용Permalink

 

interface StringRegexObject {
  [key: string]: RegExp;
}

const obj: StringRegexObject {
  cssFile: /\.css$/,
  jsFile: /\.js$/
}

Interface 확장Permalink

 

extends 키워드를 사용한다

interface Person {
  name: string;
  age: number;
}

interface Developer extends Person {
  skill: string;
}

const juniorDeveloper = {
  name: 'yeom',
  age: 29,
  skill: 'sleep'
}

4. 타입 별칭(type aliases)Permalink

 

type 키워드는 interface와는 다르게 새로운 타입을 생성하는 것이 아닌 별칭을 부여하는 것이다. extends 키워드는 사용할 수 없다.

타입 별칭 선언 및 활용Permalink

 

type MyString = string;
const str: MyString = 'I love you';

type Todo = { 
  id: string;
  title: string;
  done: boolean;
};

function getTodo(todo: Todo) {
  console.log(todo);
}

5. 연산자(Operator)Permalink

Union TypePermalink

 

한 가지 이상의 type을 선언하고자 할 때 사용할 수 있다. | 기호를 사용한다

function logMessage(value: string | number) {	// 함수 호출시 value 인자의 타입에는 string 또는 number
  if(typeof value === 'string') {
    value.toString();
  } else if(typeof value === 'number') {
    value.toLocaleString();
  } else {
    throw new TypeError('value must be string or number');
  }
}

logMessage('hello');
logMessage(100);

Intersection TypePermalink

 

합집합과 같은 개념. 함수 호출의 경우. 함수 인자에 명시한 type을 모두 제공해야 한다. & 키워드를 사용한다.

interface Zoo {
    name: string;
    location: string;
    price: number;
}

interface Animal {
    name: string;
    count: number;
}

// Union: Zoo나 Animal에 해당하는 인자를 제공해야 한다
askZookeeper({ name: 'tiger', count: 3});

// Intersection: Zoo나 Animal에 해당하는 인자를 줘야한다(합집합 같은 개념)
askZookeeper2({ name: '어린이대공원', location: '서울시 광진구', price: 10000, count: 10000 });

6. EnumPermalink

 

enum 키워드를 사용하면 일종의 default 값을 선언할 수 있다.

숫자형 enumPermalink

 

자동으로 0에서 1씩 증가하는 값을 부여

enum Shoes {
  Nike,				// 0
  Adidas,			// 1
  NewBalance	// 2
}

const myShoes = Shoes.Nike;	// 0

문자형 enumPermalink

 

enum Player {
  Koke = '코케',
  Saul = '사울'
}

const player = Player.Koke;	// 코케

7. ClassPermalink

Class에서의 타입 선언Permalink

 

class Tiger {
  // constructor 위에 선언
  private name: string;
  public age: number;
  readonly log: string;
  
  constructor(name: string, age: number) {
    this.name = name;
    this.age = age;
  }
}

8. 제네릭(generics)Permalink

 

제네릭을 활용하면 인자를 넘겨 호출하는 시점에 타입을 결정할 수 있다. 제네릭을 활용하면 동일한 기능을 하는 함수를 일일이 만들 필요가 없으며, 타입 추론에 있어서 강점을 가진다.

경축! 아무것도 안하여 에스천사게임즈가 새로운 모습으로 재오픈 하였습니다.
어린이용이며, 설치가 필요없는 브라우저 게임입니다.
https://s1004games.com

제네릭 선언Permalink

 

<T>와 같이 타입을 선언한다. 알파벳은 통상 T로 정해져 있다.

function logText<T>(text: T): T {
  consol.log(text);
  return text;
}

logText<string>('Hello My World!');

interface에 제네릭 선언Permalink

 

interface Dropdown<T> {
	value: T;
  selected: boolean;
}

const obj: Dropdown<string> = { value: 'hamburger', selected: true };

제네릭 타입 제한Permalink

1. 배열 힌트Permalink

 

function logTextLength<T>(text: T[]): T[] {
    console.log(text.length);
    text.forEach(text => {
        console.log(text);
    });
    return text;
}

logTextLength<string>(['hi', 'hello']);

2. 정의된 타입 이용(extends)Permalink

 

interface LengthType {
    length: number;
}

function logTextLen<T extends LengthType>(text: T): T {
    console.log(text.length);
    return text;
}

logTextLen('abc');
// logTextLen(100); // 숫자에 length property가 없으므로 에러
logTextLen({ length: 100 });

3. keyofPermalink

 

interface에 정의된 key 값만을 허용

interface ShoppingItem {
    name: string;
    price: number;
    stock: number;
}

function getShoppingItemOption<T extends keyof ShoppingItem>(itemOption: T): T {
    return itemOption;
}

// 'name', 'price', 'stock'만 인자로 가능
getShoppingItemOption('price');

9. 타입 추론(type inference)Permalink

기본 변수 타입 추론Permalink

 

// string으로 추론
let a = 'abc';	

// a: number로 추론
// b: string으로 추론
// return value는 string으로 추론
function getValue(a = 10) {
  let b = 'hello';
  return a + b;
}

interface 추론Permalink

 

// interface 1개
interface Dropdown<T> {
    value: T;
    title: string;
}
const shoppingItem: Dropdown<number> = {
    value: 10000,
    title: 'shoe'
}

// interface 2개
interface Dropdown2<T> {
    value: T;
    title: string;
}
interface DetailedDropdown<K> extends Dropdown2<K> {
    tag: K;
    desc: string;    
}
const detailed: DetailedDropdown<string> = {
    value: '10000',
    title: 'shoe',
    tag: '10000',
    desc: 'description'
}

10. 타입 단언(type assertion)Permalink

 

as 키워드를 사용해 타입을 정함으로써 typescript에게 타입을 알려줄 수 있다. 주로 DOM API를 조작할 때 사용한다고 한다.

타입 단언 예제Permalink

 

// div가 있는지 장담할 수 없음, HTMLDivElement | null
// 따라써 typescript에게 타입 단언해 타입을 알려 줄 수 있다.
const div = document.querySelector('div') as HTMLDivElement;
div.innerText = 'test';

11. 타입 가드(type guard)Permalink

 

Union Type을 사용하는 경우 공통된 속성만 접근이 되므로, 로직상 공통되지 않은 속성에 접근하고자 할 때 불편함이 따를 수 있다. 타입 단언으로 공통되지 않은 속성에 접근하고자 하는 방법이 있지만, 코드가 지저분해지므로 타입 가드 방법을 사용한다.

타입 가드 예제Permalink

 

function isDeveloper(target: Developer | Humanoid): target is Developer {
    return (target as Developer).skill !== undefined;
}

if(isDeveloper(tom)) {
    console.log(tom.name);
    console.log(tom.skill);
} else {
    console.log(tom.name);
    console.log(tom.age)
}

12. 타입 호환(type compatibility)Permalink

 

typescript에서는 더 큰 타입 구조를 갖는 변수에 작은 타입 구조를 갖는 변수를 할당할 수 있다. 예제를 보자.

타입 호환 예제Permalink

 

let add = function(a: number) {
    // ...
}
let sum = function(a: number, b: number) {
    // ...
}
// 아래는 에러가 난다
// add = sum;

// 에러가 나지 않는다. sum의 구조가 더 크다고 볼 수 있으므로.
sum = add;

 

 

[출처] https://yeomkyeorae.github.io/typesciprt/basic_typescript/#1-%EA%B8%B0%EB%B3%B8-ts-%ED%83%80%EC%9E%85-%EC%84%A0%EC%96%B8

 

본 웹사이트는 광고를 포함하고 있습니다.
광고 클릭에서 발생하는 수익금은 모두 웹사이트 서버의 유지 및 관리, 그리고 기술 콘텐츠 향상을 위해 쓰여집니다.
번호 제목 글쓴이 날짜 조회 수
487 [JavaScript] [JS] CORS 정리 및 오류 해결 졸리운_곰 2023.05.09 22
486 [node.js 응용] Build a Node.js Proxy Server in Under 10 minutes! file 졸리운_곰 2023.05.07 18
485 [node.js 응용] node - pm2로 node.js 프로세스 관리하기 - 기본 명령어, 실행하기 file 졸리운_곰 2023.04.25 10
484 [node.js 응용] Node.js | MySQL과 연동(mysql모듈) - CRUD 2/2 졸리운_곰 2023.03.31 7
483 [node.js 응용] Node.js | MySQL과 연동(mysql모듈) - CRUD 1/2 file 졸리운_곰 2023.03.31 8
482 [Javascript][persistent storage] persistent storage of Javascript file 졸리운_곰 2023.02.05 11
481 [JavaScript] 자바스크립트 객체 배열에서 indexOf 사용방법 졸리운_곰 2023.01.26 9
480 [HTML/Javascript] 웹소켓(WEBSOCKET) 시작하기(강의,번역) file 졸리운_곰 2022.11.15 15
479 [HTML/Javascript] 웹소켓 튜터리얼 졸리운_곰 2022.11.15 4
478 [HTML, Javascript] JavaScript에 변수가 있는지 확인 졸리운_곰 2022.11.15 10
477 [html, javascript] JavaScript에서 함수가 완료 될 때까지 기다립니다 졸리운_곰 2022.11.15 44
476 [IE javascript to Chrome] A universal createPopup() replacement 졸리운_곰 2022.11.14 8
» [web개발][javascript] TypeScript 기본 문법 정리 졸리운_곰 2022.11.05 11
474 [HTML/Javascript] indexedDB에 대해 알아보자! file 졸리운_곰 2022.09.15 57
473 [HTML][Javascript] JavaScript - DOM 요소의 생성 및 삭제, innerHTML, CSS 스타일 적용, JavaScript 스타일 적용 file 졸리운_곰 2022.09.09 9
472 [HTML] Div 를 새창 팝업으로 띄우기 졸리운_곰 2022.09.09 7
471 [Web Design][웹 디자인] Sass(SCSS) 완전 정복! 졸리운_곰 2022.07.31 91
470 [Apache 운영] 404 에러페이지 전환 How to Redirect 404 to Homepage using .htaccess 졸리운_곰 2022.07.28 46
469 [JWT} [WEB] JWT(Json Web Token)란? 개념 정리 및 예제 file 졸리운_곰 2022.07.15 38
468 [php worldpress] [위 에]wordpress 사용자 암호 화 원리 및 알고리즘 분석 졸리운_곰 2022.04.11 13
대표 김성준 주소 : 경기 용인 분당수지 U타워 등록번호 : 142-07-27414
통신판매업 신고 : 제2012-용인수지-0185호 출판업 신고 : 수지구청 제 123호 개인정보보호최고책임자 : 김성준 sjkim70@stechstar.com
대표전화 : 010-4589-2193 [fax] 02-6280-1294 COPYRIGHT(C) stechstar.com ALL RIGHTS RESERVED