TypeScript 1

holang-i·2023년 5월 30일
0
post-thumbnail

TypeScript란?

JavaScript의 한계를 TypeScript가 보완한 상위 집합(Superset) 언어로 JS에 정적타입 검사와 클래스 기반 객체지향프로그래밍 등의 기능을 추가하여 개발된 언어로, JS가 발전하면서 생긴 단점을 보완하기 위해 등자앟게 되었다.


TypeScript 프로젝트 환경 구성

1. 프로젝트 폴더 생성

mkdir [typescript-exam] // [폴더 명] 

2. 생성한 프로젝트 폴더로 이동, 터미널에서 명령어를 실행하여 새로운 프로젝트를 초기화

cd [typescript-exam] // [폴더 명]
npm init -y

3. 프로젝트 내부에서 npm을 사용할 수 있으므로 TypeScript를 설치한다.

npm install typescript --save-dev

4. 프로젝트 root 디렉토리에 tsconfig.json 파일을 생성하고 아래의 내용을 입력한다

아래 내용을 입력하면 src 폴더에 typescript언어로 된 파일을 작성할 수 있다.

//compilerOptions 내의 속성은 자유롭게 커스텀 가능
{
  "compilerOptions": {
    "target": "es6",
    "module": "commonjs",
    "sourceMap": true,
    "outDir": "./dist"
  },
  "include": [
    "src/**/*"
  ]
}

TypeScript ESLint & Prettier 설정

ESLint 설치 및 설정

  1. VSCode 에디터에서 ESLint 확장 프로그램 설치

  2. VSCode 에디터에 아래 설정 적용하기
    cmd + shift + p로 setting.json 파일 찾기

{
  // ... 
  "editor.codeActionsOnSave": {
      "source.fixAll.eslint": true
  },
  "eslint.alwaysShowStatus": true,
  "eslint.workingDirectories": [
      {"mode": "auto"}
  ],
  "eslint.validate": [
      "javascript",
      "typescript"
  ],
}

위 내용은 사용자 설정에 넣어야 하는데 기존에 설치한 확장 프로그램들이 있다면 이미 다른 설정들이 작성되어 있을 수 있다. 채워져 있는 경우 기존 코드 아래에 내용을 입력해 준다.

  1. VSCode 에디터 설정중 format on save가 설정되어있는 지 확인한다.
    체크되어 있다면 해제하기
    설정으로 이동하는 커맨드:cmd + ,


Prettier 설치 및 설정

  1. Prettier 확장 프로그램 설치

  2. 몇가지 필요한 프리셋과 라이브러리 설치

npm i -D @babel/core @babel/preset-env @babel/preset-typescript @typescript-eslint/eslint-plugin @typescript-eslint/parser eslint prettier eslint-plugin-prettier
  1. 프로젝트 폴더 밑에 .eslintrc.js 파일을 만들고 아래의 내용을 입력
module.exports = {
  root: true,
  env: {
    browser: true,
    node: true,
    jest: true,
  },
  extends: [
    'plugin:@typescript-eslint/eslint-recommended',
    'plugin:@typescript-eslint/recommended',
  ],
  plugins: ['prettier', '@typescript-eslint'],
  rules: {
    'prettier/prettier': [
      'error',
      {
        singleQuote: true,
        tabWidth: 2,
        printWidth: 80,
        bracketSpacing: true,
        arrowParens: 'avoid',
      },
    ],
    '@typescript-eslint/no-explicit-any': 'off',
    '@typescript-eslint/explicit-function-return-type': 'off',
    'prefer-const': 'off',
  },
  parserOptions: {
    parser: '@typescript-eslint/parser',
  },
};

위 파일 내부에는 prettiertypescript-eslint에 대한 설정, react를 위한 설정이 되어 있다.
rules 내에 작성된 코드는 옵션이다.


TypeScript를 사용했을 때의 장점

  • 정적타입 검사 기능을 제공하며, 코드의 가독성과 유지 보수성을 높여준다.
    - 이를 통해서 개발자는 런타임 에러를 최소화하고, 코드 작성 시간을 단축하며, 코드의 가독성을 높일 수 있다.
    - 런타임 에러를 미리 방지할 수 있기 때문에 유지보수성 또한 높아진다.
  • TypeScript는 ES6의 문법을 포함한 최신 JS 문법을 지원하며, Interface(인터페이스), Generic(제네릭), Decorators(데코레이터) 등의 긴으을 제공하여 객체 지향 프로그래밍을 보다 쉽게할 수 있도록 도와준다.

Interface를 사용하여 코드의 가독성을 높인 예

interface Student {
  id: number;
  name: string;
}

const greetingStudent = (user: Student) => {
  console.log(`Hello, ${user.name}!`);
}

const student1 = {
  id: 1,
  name: "kimcoding"
}

greetingStudent(student1);
  • 위의 코드는 Student Interface를 정의하여 Student의 정보를 조금 더 쉽게 파악할 수 있다.
  • greetingStudent 함수에도 매개변수로 Student 타입을 사용하여 이 함수가 어떤 타입의 인자를 받는지 명확하게 표현되고 있다.

TypeScript의 특징

설명
1. 정적 타입 검사 기능을 제공, 코드의 가독성 및 유지 보수성을 높여준다.
2. 기존 JavaScript는 함수와 변수의 타입을 명시적으로 지정하지 않아도 동작하는 경우가 많았고, 그 부분을 보완하여 런타임 에러를 최소화 시킨다.
3. Class, Interface 등의 기능을 제공하여 객체지향 프로그래밍을 보다 쉽게 할 수 있도록 도와준다.

TypeScript의 타입


TypeScript의 연산자 활용 타임


Union & Intersection


profile
🌿 주니어 프론트엔드 개발자입니다! 부족하거나 잘못된 정보가 있다면 알려주세요:)

0개의 댓글