개발에 도움이 되는/TypeScript

TypeScript 개념 및 설치 방법 (React)

쏠로몬 2022. 4. 6. 01:12

- TypeScript 

JavaScript의 SuperSet(상위 확장)인 오픈소스 프로그래밍 언어이다.

동적 타입인 JavaScript는 소규모일 땐 편할지 몰라도 대규모 혹은 다른 사람과 협업을 해야 되는 상황에서는 동적 타입은 직관적으로 어떤 타입의 변수인지 알 수 없어 치명적이다. TypeScript는 JavaScript에 Type 문법을 더하여 이러한 문제를 해소하고자 나왔다. 또한 에러 메시지 수준도 올라갔다.

 

- 기본 설치 (기본 html + css + typescript 개발 시)

 1) typescript 설치 (global)

npm install -g typescript

 2) tsconfig.json 생성 후 아래 내용 작성

{
  "compilerOptions": {
    "target": "es5",  // 자바스크립트 몇 버전으로 컴파일할 것인지
    "module": "commonjs",  // 모듈 import를 언제적 자바스크립트 문법으로 할 것인지
  }
}

 3) 트랜스파일러 자동 실행

tsc -w

 

 

 

- React에서의 TypeScript 사용 방법

 1) CRA로 시작하기

npx create-react-app [프로젝트 이름] --template typescript

 1-1) 만약 기존에 있는 CRA에 설치하고 싶다면

npm install --save typescript @types/node @types/react @types/react-dom @types/jest

 

  2) CRA로 시작했다면 tsconfig.json가 자동으로 생성되지만 그렇지 않은 경우 tsconfig.json을 생성 후 아래 내용 작성

{
  "compilerOptions": {
    "target": "es5",
    "lib": [
      "dom",
      "dom.iterable",
      "esnext"
    ],
    "allowJs": true,
    "skipLibCheck": true,
    "esModuleInterop": true,
    "allowSyntheticDefaultImports": true,
    "strict": true,
    "forceConsistentCasingInFileNames": true,
    "noFallthroughCasesInSwitch": true,
    "module": "esnext",
    "moduleResolution": "node",
    "resolveJsonModule": true,
    "isolatedModules": true,
    "noEmit": true,
    "jsx": "react-jsx"
  },
  "include": [
    "src"
  ]
}

 3) type에 따라 확장자명을 tsx or ts로 code 작성

 

참고 : 기존에 설치했던 library 앞에 @types/를 붙여서 설치하면 typescript용으로 porting한 library로 설치가 된다.

 ex)

// 기존 JavaScript 이용 시 설치 방법
npm i styled-components

// TypeSciprt 이용시 설치 방법
npm i @types/styled-components

 

반응형