Next.js-TypeScript 지원

Next.js는 typescript에 대한 탁월한 지원을 제공합니다. 다음은 프로젝트에서 typescript를 활성화하는 몇 가지 단계입니다.

tsconfig.json 만들기

루트 디렉터리에 tsconfig.json을 만듭니다. 처음에는 비워두고 있습니다. 이제 서버를 시작하십시오.

Next.JS는 tsconfig.json을 감지하고 콘솔에 다음 메시지를 표시합니다.

npm run dev

> [email protected] dev D:\Node\nextjs
> next

ready - started server on http://localhost:3000
It looks like you're trying to use TypeScript but do not have the required package(s) installed.

Please install typescript, @types/react, and @types/node by running:

        npm install --save-dev typescript @types/react @types/node

If you are not trying to use TypeScript, please remove the tsconfig.json file from your package root (and any TypeScript files).
...

typescript 설치

npm install 명령을 실행하여 typescript 및 관련 라이브러리를 설치합니다.

npm install --save-dev typescript @types/react @types/node
...

+ @types/[email protected]
+ @types/[email protected]
+ [email protected]
added 5 packages from 72 contributors and audited 839 packages in 27.538s
...

Next.js 서버 시작

서버를 시작하려면 다음 명령을 실행하십시오-.

npm run dev

> [email protected] dev D:\Node\nextjs
> next

ready - started server on http://localhost:3000
We detected TypeScript in your project and created a tsconfig.json file for you.


Your tsconfig.json has been populated with default values.

event - compiled successfully
wait  - compiling...
event - compiled successfully

tsconfig.json을 엽니 다.

NextJS 서버가 tsconfig.json을 수정했습니다.

{
   "compilerOptions": {
      "target": "es5",
      "lib": [
         "dom",
         "dom.iterable",
         "esnext"
      ],
      "allowJs": true,
      "skipLibCheck": true,
      "strict": false,
      "forceConsistentCasingInFileNames": true,
      "noEmit": true,
      "esModuleInterop": true,
      "module": "esnext",
      "moduleResolution": "node",
      "resolveJsonModule": true,
      "isolatedModules": true,
      "jsx": "preserve"
   },
   "exclude": [
      "node_modules"
   ],
   "include": [
      "next-env.d.ts",
      "**/*.ts",
      "**/*.tsx"
   ]
}

hello.ts 만들기

페이지 / api 디렉토리에 hello.ts를 만들어 나머지 서비스 역할을합니다.

import { NextApiRequest, NextApiResponse } from 'next'

export default (_: NextApiRequest, res: NextApiResponse) => {
   res.status(200).json({ text: 'Welcome to TutorialsPoint' })
}

Next.js 서버 시작

서버를 시작하려면 다음 명령을 실행하십시오-.

npm run dev
> [email protected] dev \Node\nextjs
> next

ready - started server on http://localhost:3000
event - compiled successfully
event - build page: /
wait  - compiling...
event - compiled successfully
event - build page: /next/dist/pages/_error
wait  - compiling...
event - compiled successfully

출력 확인

브라우저에서 localhost : 3000 / api / hello를 열면 다음 출력이 표시됩니다.

{"text":"Welcome to TutorialsPoint"}