Next.js

Next.js アプリにダークモードを追加する方法。

next-themes をインストール

next-themes をインストールします:

pnpm add next-themes

テーマプロバイダーを作成

components/theme-provider.tsx
"use client"
 
import * as React from "react"
import { ThemeProvider as NextThemesProvider } from "next-themes"
 
export function ThemeProvider({
  children,
  ...props
}: React.ComponentProps<typeof NextThemesProvider>) {
  return <NextThemesProvider {...props}>{children}</NextThemesProvider>
}

ルートレイアウトをラップ

ThemeProvider をルートレイアウトに追加し、html タグに suppressHydrationWarning プロパティを付けてください。

app/layout.tsx
import { ThemeProvider } from "@/components/theme-provider"
 
export default function RootLayout({ children }: RootLayoutProps) {
  return (
    <>
      <html lang="ja" suppressHydrationWarning>
        <head />
        <body>
          <ThemeProvider
            attribute="class"
            defaultTheme="system"
            enableSystem
            disableTransitionOnChange
          >
            {children}
          </ThemeProvider>
        </body>
      </html>
    </>
  )
}

モード切替を追加

サイトにモード切替を配置して、ライトモードとダークモードを切り替えられるようにします。

Component mode-toggle not found in registry.