-
Notifications
You must be signed in to change notification settings - Fork 198
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. Weโll occasionally send you account related emails.
Already on GitHub? Sign in to your account
๐ 02-app > 01-building-your-application > 08-upgrading > 02-app-router-migration.mdx ๋ฒ์ญ #255
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
๊ธด ๊ธ ๋ฒ์ญํ๋๋ผ ๊ณ ์ํ์ จ์ต๋๋ค!
docs/02-app/01-building-your-application/08-upgrading/02-app-router-migration.mdx
Outdated
Show resolved
Hide resolved
docs/02-app/01-building-your-application/08-upgrading/02-app-router-migration.mdx
Outdated
Show resolved
Hide resolved
docs/02-app/01-building-your-application/08-upgrading/02-app-router-migration.mdx
Outdated
Show resolved
Hide resolved
docs/02-app/01-building-your-application/08-upgrading/02-app-router-migration.mdx
Outdated
Show resolved
Hide resolved
docs/02-app/01-building-your-application/08-upgrading/02-app-router-migration.mdx
Outdated
Show resolved
Hide resolved
๋จ๊ฒจ์ฃผ์ ์ฝ๋๋ฆฌ๋ทฐ ์ฌํญ ๊ด๋ จํด์ ์ถ๊ฐ์ ์ผ๋ก ๋์น ๋ถ๋ถ๋ค์๋ ์ฐ์ ๋ฆฌ๋ทฐ์ฌํญ ์ ์ฉํ์์ต๋๋ค. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
์๊ณ ํ์
จ์ต๋๋ค! ๋ฆฌ๋ทฐ ๋ฐ์ ๋ถํ๋๋ฆฝ๋๋ค.
์๋ฌธ์ด ๊ธธ์ด์ ๋ฆฌ๋ทฐ๋ ๊ธธ์ด์ก๋๋ฐ ์ํด ๋ถํ ๋๋ฆฝ๋๋ค.
ํน์ pnpm run prettier-fix๋ฅผ ์คํํ์ จ๋์? ๋ณธ๋ฌธ ์ค์ ํ ๋ฌธ์ฅ ์ฌ์ด์ ์ํฐ๊ฐ ๋ค์ด๊ฐ ๋ถ๋ถ์ด ๊ฝค ๋ง์์, ์์ ํ pnpm run prettier-fix ์คํ ๋ถํ๋๋ฆฝ๋๋ค. ๐
nav_title: App Router Migration | ||
description: Learn how to upgrade your existing Next.js application from the Pages Router to the App Router. | ||
title: App Router ์ ์ง์ ์ ์ฉ ๊ฐ์ด๋ | ||
nav_title: App Router ๋ง์ด๊ทธ๋ ์ด์ |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
description: Learn how to upgrade your existing Next.js application from the Pages Router to the App Router. | ||
title: App Router ์ ์ง์ ์ ์ฉ ๊ฐ์ด๋ | ||
nav_title: App Router ๋ง์ด๊ทธ๋ ์ด์ | ||
description: Next.js ์ดํ๋ฆฌ์ผ์ด์ ์ Pages Router์์ App Router๋ก ์ ๊ทธ๋ ์ด๋ํ๋ ๋ฐฉ๋ฒ์ ๋ฐฐ์๋๋ค. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
ํ์ด์ง ๋ผ์ฐํฐ ๋ํ ์๊ธฐ ๋์ผํฉ๋๋ค! :)
--- | ||
|
||
This guide will help you: | ||
์ด ๊ฐ์ด๋๋ ๋น์ ์ ๋์์ค ๊ฒ์ ๋๋ค. | ||
|
||
- [Update your Next.js application from version 12 to version 13](#nextjs-version) | ||
- [Upgrade features that work in both the `pages` and the `app` directories](#upgrading-new-features) | ||
- [Incrementally migrate your existing application from `pages` to `app`](#migrating-from-pages-to-app) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
๋งํฌ๋ ๋ฌธ์์ ๋๊ดํธ ์์ชฝ(๋ฌธ์ ์ ๋ชฉ)๋ ๋ฒ์ญ ๋ถํ๋๋ฆฝ๋๋ค :)
|
||
The minimum Node.js version is now **v16.8**. See the [Node.js documentation](https://nodejs.org/docs/latest-v16.x/api/) for more information. | ||
ํ์ฌ ์ต์ Node.js ๋ฒ์ ์ **v16.8**์ ๋๋ค. ์์ธํ ๋ด์ฉ์ [Node.js ์ค๋ช ์](https://nodejs.org/docs/latest-v16.x/api/) ๋ฅผ ์ฐธ์กฐํ์ธ์. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
์ค๋ช ์ ๋ณด๋จ ๋ฌธ์๊ฐ ์ ํฉํ๋ค๊ณ ์๊ฐ๋๋๋ฐ ์ด๋ ์ค๊น์?
|
||
```bash filename="Terminal" | ||
npm install -D eslint-config-next@latest | ||
``` | ||
|
||
> **Good to know**: You may need to restart the ESLint server in VS Code for the ESLint changes to take effect. Open the Command Palette (`cmd+shift+p` on Mac; `ctrl+shift+p` on Windows) and search for `ESLint: Restart ESLint Server`. | ||
> **์ฐธ๊ณ **: ESLint ๋ณ๊ฒฝ ์ฌํญ์ ์ ์ฉํ๋ ค๋ฉด VS Code์์ ESLint ์๋ฒ๋ฅผ ๋ค์ ์์ํด์ผ ํ ์ ์์ต๋๋ค. ๋ช ๋ น ํ๋ ํธ(Mac์ ๊ฒฝ์ฐ 'cmd+shift+p', Windows์ ๊ฒฝ์ฐ 'ctrl+shift+p')๋ฅผ ์ด๊ณ 'ESLint: ESLint ์๋ฒ ๋ค์ ์์'์ ๊ฒ์ํฉ๋๋ค. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
cmd+shift+p ์ ctrl+shift+p, ESLint: Restart ESLint Server ๋ ๋ฐฑํฑ์ผ๋ก ๊ฐ์ธ์ฃผ์ธ์!
|
||
### Step 6: Migrating Data Fetching Methods | ||
### 6๋จ๊ณ: ๋ฐ์ดํฐ ๊ฐ์ ธ์ค๊ธฐ ๋ฐฉ๋ฒ ๋ง์ด๊ทธ๋ ์ด์ |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
๋ฐ์ดํฐ ๊ฐ์ ธ์ค๊ธฐ > Data fetching
|
||
The `pages` directory uses `getServerSideProps` and `getStaticProps` to fetch data for pages. Inside the `app` directory, these previous data fetching functions are replaced with a [simpler API](/docs/app/building-your-application/data-fetching) built on top of `fetch()` and `async` React Server Components. | ||
`pages` ๋๋ ํ ๋ฆฌ | ||
๋ `getServerSideProps`์ `getStaticProps`๋ฅผ ์ฌ์ฉํ์ฌ ํ์ด์ง ๋ฐ์ดํฐ๋ฅผ ๊ฐ์ ธ์ต๋๋ค. `app` ๋๋ ํ ๋ฆฌ ๋ด์์ ์ด๋ฌํ ์ด์ ์ ๋ฐ์ดํฐ ๊ฐ์ ธ์ค๊ธฐ ๊ธฐ๋ฅ์ `fetch()` ๋ฐ `async` React Server Components ์์ ๊ตฌ์ถ๋ [๊ฐ๋จํ API](/docs/app/building-your-application/data-fetching)๋ก ๋์ฒด๋ฉ๋๋ค. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
๋ฐ์ดํฐ ๊ฐ์ ธ์ค๊ธฐ > Data fetching
@@ -634,16 +682,15 @@ async function getData() { | |||
} | |||
|
|||
export default async function Page() { | |||
// You can use `cookies()` or `headers()` inside Server Components | |||
// directly or in your data fetching function | |||
// ์๋ฒ ์ปดํฌ๋ํธ ๋ด ์ง์ ๋๋ ๋ฐ์ดํฐ ๊ฐ์ ธ์ค๊ธฐ ๊ธฐ๋ฅ์์ `cookies()` ๋๋ `header()`๋ฅผ ์ฌ์ฉํ ์ ์์ต๋๋ค. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
๋ฐ์ดํฐ ๊ฐ์ ธ์ค๊ธฐ > data fetching
@@ -653,20 +700,19 @@ async function getData() { | |||
} | |||
|
|||
export default async function Page() { | |||
// You can use `cookies()` or `headers()` inside Server Components | |||
// directly or in your data fetching function | |||
// ์๋ฒ ์ปดํฌ๋ํธ ๋ด ์ง์ ๋๋ ๋ฐ์ดํฐ ๊ฐ์ ธ์ค๊ธฐ ๊ธฐ๋ฅ์์ `cookies()` ๋๋ `header()`๋ฅผ ์ฌ์ฉํ ์ ์์ต๋๋ค. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
๋ฐ์ดํฐ ๊ฐ์ ธ์ค๊ธฐ > data fetching
@@ -867,11 +914,12 @@ export async function GET(request: Request) {} | |||
export async function GET(request) {} | |||
``` | |||
|
|||
> **Good to know**: If you previously used API routes to call an external API from the client, you can now use [Server Components](/docs/getting-started/react-essentials#server-components) instead to securely fetch data. Learn more about [data fetching](/docs/app/building-your-application/data-fetching/fetching). | |||
> **์ฐธ๊ณ **: ์ด์ ์ API ๊ฒฝ๋ก๋ฅผ ์ฌ์ฉํ์ฌ ํด๋ผ์ด์ธํธ์์ ์ธ๋ถ API๋ฅผ ํธ์ถํ๋ค๋ฉด ์ด์ [์๋ฒ ์ปดํฌ๋ํธ](/docs/getting-started/react-essentials#server-components)๋ฅผ ์ฌ์ฉํ์ฌ ๋ฐ์ดํฐ๋ฅผ ์์ ํ๊ฒ ๊ฐ์ ธ์ฌ ์ ์์ต๋๋ค. [๋ฐ์ดํฐ ๊ฐ์ ธ์ค๊ธฐ](/docs/app/building-your-application/data-fetching/fetching)์ ๋ํด ์์ธํ ์์๋ณด์ญ์์ค. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
๋ฐ์ดํฐ ๊ฐ์ ธ์ค๊ธฐ > data fetching
ref #91 |
@haileyport ๋ฆฌ๋ทฐ ๊ฐ์ฌํฉ๋๋ค! ์ถ๊ฐ์ ์ฉํ์ฌ ํธ์ํด๋์์ต๋๋ค! |
@haileyport ์ ๊ฐ ์จ๊ฒจ์ง ๋ฆฌ๋ทฐ๋ค์ ๋์ค์ ๋ฐ๊ฒฌํด์ ์ ๋ถ ์ถ๊ฐ๋ก ์ ์ฉํด๋์์ต๋๋ค! ๋ณธ๋ฌธ์ด ์ ๋ง ๊ธธ์๋๋ฐ ๊ผผ๊ผผํ๊ฒ ๋ด์ฃผ์ ์ ๋๋ฌด ๊ฐ์ฌํฉ๋๋ค~๐ |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
๊ธด ๊ธ ์์ ํ๋๋ผ ๊ณ ์ํ์ จ์ต๋๋ค ๐ ๋ช ๊ฐ์ง๋ง ๊ณ ์ณ์ฃผ์๋ฉด ๊ฐ์ฌํ๊ฒ ์ต๋๋ค!! ๐ฅฐ
- [Migrate from the `pages` to `app` directory](#migrating-from-pages-to-app): A step-by-step guide to help you incrementally migrate from the `pages` to the `app` directory. | ||
- [์๋ก์ด ๊ธฐ๋ฅ ์ ๊ทธ๋ ์ด๋](#upgrading-new-features): ํฅ์๋ ์ด๋ฏธ์ง ๋ฐ ๋งํฌ ์ปดํฌ๋ํธ | ||
์ ๊ฐ์ ์๋ก์ด ๊ธฐ๋ฅ์ผ๋ก ์ ๊ทธ๋ ์ด๋ํ๋ ๋ฐ ๋์์ด ๋๋ ์๋ด์์ ๋๋ค. | ||
- ['pages'์์ 'app' ๋๋ ํ ๋ฆฌ๋ก ๋ง์ด๊ทธ๋ ์ด์ ](#migrating-from-pages-to-app): `pages`์์ `app` ๋๋ ํ ๋ฆฌ |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
๋งํฌ ์ ๋ชฉ ๋ด์ pages์ app์ ๋ฐฑํฑ์ผ๋ก ๊ฐ์ธ์ฃผ์ธ์!
- [Update your Next.js application from version 12 to version 13](#nextjs-version) | ||
- [Upgrade features that work in both the `pages` and the `app` directories](#upgrading-new-features) | ||
- [Incrementally migrate your existing application from `pages` to `app`](#migrating-from-pages-to-app) | ||
- [๋น์ ์ Next.js ์ดํ๋ฆฌ์ผ์ด์ ์ 12 ๋ฒ์ ์์ 13 ๋ฒ์ ์ผ๋ก ์ ๋ฐ์ดํธํ์ธ์.](#nextjs-version) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
๋ชจ๋ฒ์ฌ๋ก์ ๋ฐ๋ผ '๋น์ ์', '๋น์ ์' ๊ฐ์ ํํ์ ๋น ์ ธ๋ ๊ด์ฐฎ์ ๊ฑฐ ๊ฐ์ต๋๋ค!
- [Upgrade features that work in both the `pages` and the `app` directories](#upgrading-new-features) | ||
- [Incrementally migrate your existing application from `pages` to `app`](#migrating-from-pages-to-app) | ||
- [๋น์ ์ Next.js ์ดํ๋ฆฌ์ผ์ด์ ์ 12 ๋ฒ์ ์์ 13 ๋ฒ์ ์ผ๋ก ์ ๋ฐ์ดํธํ์ธ์.](#nextjs-version) | ||
- [ํ์ด์ง ๋๋ ํ ๋ฆฌ์ ์ฑ ๋๋ ํ ๋ฆฌ ๋ชจ๋์์ ์๋ํ๋ ๊ธฐ๋ฅ์ ์ ๊ทธ๋ ์ด๋ํ๊ธฐ](#upgrading-new-features) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
ํ์ด์ง ๋๋ ํ ๋ฆฌ์ ์ฑ ๋๋ ํ ๋ฆฌ
๋ฅผ ์๋์ ๋ฒ์ญํ์ ๊ฒ ์ฒ๋ผ pages
๋๋ ํ ๋ฆฌ์ app
๋๋ ํ ๋ฆฌ ๋ก ํต์ผ ๋ถํ๋๋ฆฝ๋๋ค! (๋ฐฑํฑ ์ ์)
|
||
The [`<Link>` Component](/docs/app/building-your-application/routing/linking-and-navigating#link-component) no longer requires manually adding an `<a>` tag as a child. This behavior was added as an experimental option in [version 12.2](https://nextjs.org/blog/next-12-2) and is now the default. In Next.js 13, `<Link>` always renders `<a>` and allows you to forward props to the underlying tag. | ||
[`<Link>` ์ปดํฌ๋ํธ](/docs/app/building-your-application/routing/link-and-navigation#link-component)๋ ๋ ์ด์ ์๋์ผ๋ก `<a>` ํ๊ทธ๋ฅผ ์์์ผ๋ก ์ถ๊ฐํ ํ์๊ฐ ์์ต๋๋ค. ์ด ๋์์ [๋ฒ์ 12.2](https://nextjs.org/blog/next-12-2)์์ ์คํ ์ต์ ์ผ๋ก ์ถ๊ฐ๋์์ผ๋ฉฐ ํ์ฌ ๊ธฐ๋ณธ๊ฐ์ ๋๋ค. Next.js 13์์ `<Link>`๋ ํญ์ `<a>`๋ฅผ ๋ ๋๋งํ๊ณ ๊ธฐ๋ณธ ํ๊ทธ๋ก ์ํ์ ์ ๋ฌํ ์ ์์ต๋๋ค. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
/docs/app/building-your-application/routing/linking-and-navigating#link-component
๊ฐ ์ฌ๋ฐ๋ฅธ ์ฃผ์์
๋๋ค :)
@haileyport ์ถ๊ฐ ๋ฆฌ๋ทฐ ์ฌํญ ํ์ธ ๋ฐ prettier-fix ๊น์ง ์๋ฃํ์์ต๋๋ค! ๊ฐ์ฌํฉ๋๋ค. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM๐
๊ธด ๋ด์ฉ ์ ๋ง ๊ณ ์ ๋ง์ผ์
จ์ต๋๋ค ๐ฅน ์ถ๊ฐ์ ์ผ๋ก ๋ ๋ฒ์ญํ๊ณ ์ถ์ ๋ถ๋ถ์ด ์์ผ์๋ค๋ฉด ์ด์์ ๋๊ธ ๋จ๊ฒจ์ฃผ์ธ์!
๊ธฐ์ฌ์์ฉ
๋ฌธ์ ๊ฐ์
pnpm prettier-fix
๋ฅผ ์คํํ์ฌ ์์ ๋ฌธ์ ๋ฅผ ํด๊ฒฐํฉ๋๋ค. - ๋ฌธ์ ๊ธฐ์ฌ ๊ฐ์ด๋๋ฅผ ์ฝ๊ณ ๋ฌธ์ ์ง์นจ์ ๋ฐ๋ฅด๋์ง ํ์ธํ์ธ์: https://github.com/Nextjs-kr/Nextjs.ko/blob/main/packages/next/README.mdProgress
pnpm prettier-fix