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을 열면 다음과 같은 출력이 표시됩니다.

첫 번째 게시물 링크를 클릭합니다.