ts와 webpack으로 react를 초기설정 해보자

npm install 초기 설정

npm install --save-dev webpack webpack-cli ts-loader typescript source-map-loader @types/react @types/react-dom
npm install --save react react-dom

tsconfig 설정

{
  "compilerOptions": {
    "outDir": "./dist/", // 결과를 저장할 경로
    "noImplicitAny": true, // 타입 검사 활성화
    "module": "ES6", // 사용할 모듈 설정
    "target": "ES5", // 사용할 ECMAScript 버전 설정
    "jsx": "react", // jsx 지원
    "allowJs": true, // js 허용
    "removeComments": true, // 주석 삭제
    "preserveConstEnums": true, // const enum 선언 제거 여부
    "sourceMap": true // 소스맵 (*.map) 파일 생성 여부
  }
}

webpack.config.js 설정

const path = require('path');

module.exports = {
    entry: {
        app: path.join(__dirname, 'src', 'index.tsx')
    },
    mode: 'development',
    devtool: 'source-map',
    module: {
        rules: [
            {
                test: /\\\\.ts(x?)$/,
                use: 'ts-loader',
                exclude: /node_modules/,
            },
            {
                enforce: 'pre',
                test: /\\\\.js$/,
                loader: 'source-map-loader'
            }
        ],
    },
    resolve: {
        extensions: ['.ts', '.tsx'],
    },
    externals: {
        'react': 'React',
        'react-dom': 'ReactDOM'
    },
    output: {
        filename: 'bundle.js',
        path: path.resolve(__dirname, 'dist')
    }
}

package.json 설정

{
  "name": "webpack-study",
  "version": "1.0.0",
  "description": "",
  "main": "index.js",
  "scripts": {
    "test": "echo \\\\"Error: no test specified\\\\" && exit 1",
    "build": "webpack --config ./webpack.config.js"
  },
  "author": "mos",
  "license": "ISC",
  "devDependencies": {
    "@types/react": "^16.9.23",
    "@types/react-dom": "^16.9.5",
    "source-map-loader": "^0.2.4",
    "ts-loader": "^6.2.1",
    "typescript": "^3.8.3",
    "webpack": "^4.42.0",
    "webpack-cli": "^3.3.11"
  },
  "dependencies": {
    "react": "^16.13.0",
    "react-dom": "^16.13.0"
  }
}

/dist/index.html 생성

<!DOCTYPE HTML>
<html>
<head>
    <title>Getting Started</title>
    <script src="<https://unpkg.com/lodash@4.16.6>"></script>
</head>
<body>
<div id="root"/>
<script src="./node_modules/react/umd/react.development.js"></script>
<script src="./node_modules/react-dom/umd/react-dom.development.js"></script>
<script src="./src/index.js"></script>
</body>
</html>

/src/index.tsx 생성

import * as React from "react";
import * as ReactDom from "react-dom";

import {Hello} from "./components/Hello";

ReactDom.render(
    <Hello name="모기" age={27}/>,
    document.getElementById("root")
);

/src/components/Hello.tsx 생성