실제로 사용한 tsconfig.json를 바탕으로 알아보자.

{
  "compilerOptions": {
    "target": "ES2022",
    "useDefineForClassFields": true,
    "module": "ESNext",
    "lib": ["ES2022", "DOM"],
    "skipLibCheck": true,

    /* Bundler mode */
    "moduleResolution": "bundler",
    "allowImportingTsExtensions": true,
    "resolveJsonModule": true,
    "isolatedModules": true,
    "noEmit": true,

    /* Type Checking */
    "strict": true,
    "noUnusedLocals": true,
    "noUnusedParameters": true,

    /* Aliases */
    "baseUrl": ".",
    "paths": {
      "@/*": ["./src/*"]
    }
  },
  "include": ["src/**/*.ts", "src/**/*.d.ts", "src/**/*.tsx", "src/**/*.vue"],
  "references": []
}

세부 옵션 설명

1. 컴파일러 옵션 (compilerOptions)

2. Bundler 모드 관련 옵션

이 옵션들은 주로 번들러(Vite, Webpack 등)와 함께 사용될 때 유용합니다.

3. 타입 체크 관련 옵션