[Next JS - 7버전] styled-components 적용

Hyuk·2023년 6월 20일

NextJS

목록 보기
3/3

[next JS] 7버전 styled-components 적용
next 업그레이드를 위해 페이지 작업도중 생긴 문제
csr과같이 css가 적용되지 않은 상태로 렌더링 된 후에 css가 적용되어 문제 발생

import Document, { Html, Head, Main, NextScript } from 'next/document'
import React from 'react'
import { ServerStyleSheet } from 'styled-components'
import Header from './Header'

export default class extends Document {
  static async getInitialProps(ctx) {
    const sheet = new ServerStyleSheet()
    const originalRenderPage = ctx.renderPage

    try {
      ctx.renderPage = () =>
        originalRenderPage({
          enhanceApp: App => props => sheet.collectStyles(<App {...props} />),
        })

      const initialProps = await Document.getInitialProps(ctx)
      return {
        ...initialProps,
        styles: (
          <>
            {initialProps.styles}
            {sheet.getStyleElement()}
          </>
        ),
      }
    } finally {
      sheet.seal()
    }
  }

  render() {
    return (
      <html>
        <Head>
          <Header />
        </Head>

        <body>
          <Main />
          <NextScript />
        </body>
      </html>
    )
  }
}

ssr을 위해서 2가지 라이브러리를 설치해줍니다.
yarn add styled-components babel-plugin-styled-components

이후 아래 구조를 확인하고 .babelrc를 생성해줍니다.

- src
- package.json
+ .babelrc

이후 아래 코드를 붙여줍니다.

.babelrc

{
  "presets": ["next/babel"],
  "plugins": [
    [
      "styled-components",
      {
        "ssr": true,
        "displayName": true,
        "preprocess": false
      }
    ]
  ]
}
profile
frontEnd Developer

0개의 댓글