Next.js-사전 렌더링
Next.js에서는 사전 렌더링이라는 페이지에 대한 HTML을 생성한다는 것을 알고 있습니다. Next.JS는 두 가지 유형의 사전 렌더링을 지원합니다.
Static Generation−이 방법은 빌드시 HTML 페이지를 생성합니다. 이 미리 렌더링 된 HTML은 각 요청에 대해 전송됩니다. 이 방법은 마케팅 웹 사이트, 블로그, 웹 사이트, 도움말, 문서 웹 사이트를 나열하는 전자 상거래 제품에 유용합니다.
Server Side Generation−이 방법은 각 요청에 대해 HTML 페이지를 생성합니다. 이 방법은 html 페이지 내용이 각 요청에 따라 다를 수있는 경우에 적합합니다.
페이지 별 사전 렌더링
Next.JS는 대부분의 페이지가 정적 생성을 따르고 다른 페이지가 서버 측 렌더링을 사용하는 각 페이지에 대해 사전 렌더링 방법을 설정할 수 있습니다.
데이터없는 정적 생성
정적 생성은 데이터없이 수행 할 수 있습니다.이 경우 HTML 페이지는 데이터를 프리 페치 한 다음 렌더링을 시작할 필요없이 준비됩니다. 나중에 또는 요청시 데이터를 가져올 수 있습니다. 이 기술은 데이터가 도착하는 데 시간이 걸리는 경우 데이터없이 사용자 인터페이스를 사용자에게 표시하는 데 도움이됩니다.
데이터를 사용한 정적 생성
정적 생성은 데이터로 수행 할 수 있습니다.이 경우 HTML은 데이터에 종속 될 수 있으므로 데이터를 가져올 때까지 HTML 페이지가 준비되지 않습니다. 각 구성 요소에는 특별한 방법이 있습니다.getStaticProps 데이터를 가져오고 페이지의 소품으로 데이터를 전달하는 데 사용할 수 있으므로 페이지가 전달 된 소품에 따라 렌더링 할 수 있습니다.
getStaticProps () 함수는 프로덕션에서 빌드시 실행되며 개발 모드의 모든 요청에 대해 실행됩니다.
같은 것을 보여주는 예제를 만들어 봅시다.
이 예에서는 데이터를 가져 오기 위해 서버 히트를 만들기 위해 업데이트 index.js 및 first.js 페이지를 생성합니다.
Global CSS Support 장 에서 사용 된 nextjs 프로젝트를 업데이트하겠습니다 .
페이지 디렉토리의 index.js 파일을 업데이트하여 getServerSideProps () 메소드를 사용하십시오. 이 메서드는 요청마다 호출됩니다.
import Link from 'next/link'
import Head from 'next/head'
function HomePage(props) {
return (
<>
<Head>
<title>Welcome to Next.js!</title>
</Head>
<div>Welcome to Next.js!</div>
<Link href="/posts/first"><a>First Post</a></Link>
<br/>
<div>Next stars: {props.stars}</div>
<img src="/logo.png" alt="TutorialsPoint Logo" />
</>
)
}
export async function getServerSideProps(context) {
const res = await fetch('https://api.github.com/repos/vercel/next.js')
const json = await res.json()
return {
props: { stars: json.stargazers_count }
}
}
export default HomePage
페이지 디렉토리의 first.js 파일을 업데이트하여 getStaticProps () 메소드를 사용하십시오. 이 메서드는 한 번 호출됩니다.
import Link from 'next/link'
import Head from 'next/head'
import Container from '../../components/container'
export default function FirstPost(props) {
return (
<>
<Container>
<Head>
<title>My First Post</title>
</Head>
<h1>My First Post</h1>
<h2>
<Link href="/">
<a>Home</a>
</Link>
<div>Next stars: {props.stars}</div>
</h2>
</Container>
</>
)
}
export async function getStaticProps() {
const res = await fetch('https://api.github.com/repos/vercel/next.js')
const json = await res.json()
return {
props: { stars: json.stargazers_count }
}
}
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을 열면 다음과 같은 출력이 표시됩니다.
첫 번째 게시물 링크를 클릭합니다.