DEV Community

Cover image for Managing Multiple Layouts in Next.js with App Router and Route Groups
THE FALCON
THE FALCON

Posted on

Managing Multiple Layouts in Next.js with App Router and Route Groups

In Next.js 13, the App Router was introduced with several exciting features, such as layouts, error boundaries, loading indicators, and more. However, some developers face challenges when managing multiple layouts at the same route level. Below, I’ll show you the best way to structure and maintain clean, convenient layouts for such scenarios.

Step 1: Create a Root Layout (Optional)

A root layout is useful for defining global components or context providers for your entire app. However, if your app doesn’t require global configurations, you can skip this step.

// app/layout.tsx

export default function RootLayout({
  children,
}: {
  children: React.ReactNode;
}) {
  return (
    <html>
      <body>
        <RootProviders>
          {children}
        </RootProviders>
      </body>
    </html>
  );
}
Enter fullscreen mode Exit fullscreen mode

Step 2: Define Layouts for Specific Route Groups

Suppose we need a Header and Footer for the /home and /contact pages. To achieve this, we can use Next.js Route Groups.

For example, we’ll create a route group called (marketing) and place our pages inside it. Pages like app/(marketing)/home/page.tsx and app/(marketing)/contact/page.tsx will use the app/(marketing)/layout.tsx layout.

// app/(marketing)/layout.tsx

export default function MarketingLayout({
  children,
}: {
  children: React.ReactNode;
}) {
  return (
    <Providers>
      <Header />
      <main>{children}</main>
      <Footer />
    </Providers>
  );
}
Enter fullscreen mode Exit fullscreen mode

Step 3: Create Layouts for Other Route Groups

Similarly, for pages like /policy and /tos, we can create a new route group called (legal) and define a specific layout for it.

// app/(legal)/layout.tsx

export default function LegalLayout({
  children,
}: {
  children: React.ReactNode;
}) {
  return (
    <>
      <Header />
      <main className="container mx-auto">{children}</main>
    </>
  );
}
Enter fullscreen mode Exit fullscreen mode

Key Benefits

Using this approach, you can:

  1. Maintain multiple layouts for routes at the same level.
  2. Keep your project structure clean and organized.
  3. Implement specific features, such as Google Analytics, for certain layouts. For example, you could add analytics tracking specifically within the LegalLayout for pages like /policy and /tos.

By leveraging Route Groups and Layouts, Next.js empowers you to create modular, scalable, and maintainable architectures for your applications.

Top comments (0)