data:image/s3,"s3://crabby-images/67802/678022d76d139155b7984ed282dd243fe20f34db" alt="Next.JS 시작하기"
1. Node.js 프로젝트를 초기화하는 명령어
npm init -y
data:image/s3,"s3://crabby-images/2408b/2408b432c3862611d03d117a59415154416ad691" alt="notion image"
2. 최신 버전 설치하기
react@latest
: React의 최신 버전 설치
react-dom@latest
: React와 함께 사용하는 DOM 관련 라이브러리의 최신 버전 설치
next@latest
: Next.js의 최신 버전 설치
npm install react@latest next@latest react-dom@latest
data:image/s3,"s3://crabby-images/99a70/99a7032a95b22955f245c9664c207b92093e4514" alt="notion image"
3. TypeScript 최신버전 설치하기
npm install --save-dev typescript @types/react @types/node
data:image/s3,"s3://crabby-images/602f8/602f8ebaaa4e71e1417cef92e2a74dee57bfcf23" alt="notion image"
npx tsc --init
data:image/s3,"s3://crabby-images/fbcac/fbcac0a8f7fdc9c788cd6794f03980826c246c88" alt="notion image"
** 한번에 설치하는 방법
npx create-next-app@latest my-app --typescript
data:image/s3,"s3://crabby-images/b2ca7/b2ca742ae08b19fa3a2bda9d71bba2efb30f9ed8" alt="notion image"
data:image/s3,"s3://crabby-images/3540b/3540b8b7cc778c3264ee3d42a676b242ef09cb9f" alt="notion image"
** 디렉토리로 이동 안하면 실행 안됨
data:image/s3,"s3://crabby-images/4362a/4362affbbd3f477fd20aa4fbe0ca8c92b1d9a86d" alt="notion image"
4. package.json 수정하기
- 스크립트 : dev
- npm run dev 명령어 사용 가능
{ "dependencies": { "next": "^14.2.5", "react": "^18.3.1", "react-dom": "^18.3.1" }, "name": "nextjs", "version": "1.0.0", "main": "index.js", "scripts": { "dev": "next dev" }, "keywords": [], "author": "", "license": "MIT", "description": "" }
6. 페이지 만들기
export default function Tomato(){ return <h1>Hello NextJS</h1> }
7. 실행하기
npm run dev
data:image/s3,"s3://crabby-images/68c89/68c8982ccce7ccd1ff2e39f0a52f5acf43e2343a" alt="notion image"
- ctrl + 클릭 → 새창 생성
data:image/s3,"s3://crabby-images/2369d/2369dd1d1ad65dad3799d81fdbaa806bbe42e8f4" alt="notion image"
data:image/s3,"s3://crabby-images/f2abb/f2abba9934276e967697de05fc661fbe7b54d184" alt="notion image"
data:image/s3,"s3://crabby-images/3aff4/3aff48e9f833afa2a683d6271ac21648a1ec5607" alt="notion image"
export const metadata = { title: 'Next.js', description: 'Generated by Next.js', } export default function RootLayout({ children, }: { children: React.ReactNode }) { return ( <html lang="en"> <body>{children}</body> </html> ) }
8. 페이지 추가하기
- 폴더 생성 → URL 생성
- 파일이 없으면 경로의 일부분이기에 에러남
- 폴더 내부에 page.tsx실제 보여지는 페이지
export default function AboutUs(){ return <h1>About Us</h1>; }
data:image/s3,"s3://crabby-images/94321/94321e8b6460a6c13d1f779745552bdbda4f0447" alt="notion image"
- 폴더만 만들어도 URL은 생성이 되나 UI를 만들지 않으면 오류남
data:image/s3,"s3://crabby-images/c3dd0/c3dd05925bf66134226ca0846b6c565911a6c146" alt="notion image"
data:image/s3,"s3://crabby-images/e3379/e3379c7f44c8a4f6472f6f4f0ca6f0133f87f0f1" alt="notion image"
data:image/s3,"s3://crabby-images/4d8b1/4d8b1dbafbac3d327f974c7fa1f13563576b58c9" alt="notion image"
9. 잘못된 URL 요청시 화면 만들기
- UI가 없는 페이지, 존재하지 않는 URL 요청시 보이는 화면
data:image/s3,"s3://crabby-images/2c5be/2c5be29e805ba7608dc7e79731fdf9acaa749f69" alt="notion image"
export default function NotFound(){ return <h1>Not Found</h1>; }
data:image/s3,"s3://crabby-images/894a5/894a59a3c427cdda6325553e9cf5166de8866d64" alt="notion image"
data:image/s3,"s3://crabby-images/8f41a/8f41a445c8ec537fd620f7229edfb66cb362e5d6" alt="notion image"
data:image/s3,"s3://crabby-images/45908/4590896ee6c8f2af9d3ff6a8cebd3dd11fb078d5" alt="notion image"
Share article