Creating a reusable layout in Next.js

Yesterday we added a menu to our Next.js application. However, this was hardcoded on one page.

Today we’ll take a look at how we can introduce a layout component to have a shared layout for our menu on each page.

Creating the layout componen…


This content originally appeared on DEV Community and was authored by Chris Bongers

Yesterday we added a menu to our Next.js application. However, this was hardcoded on one page.

Today we'll take a look at how we can introduce a layout component to have a shared layout for our menu on each page.

Creating the layout component

Create a file called layout.js in the components folder.

This file will act as the main layout. In our case, it will render the header and the children for each page.

import Header from './Header';

export default function Layout({children, menu}) {
  return (
    <>
      <Header menuItems={menu} />
      <main>{children}</main>
    </>
  );
}

The children are passed through our main page, the _app.js, and we will pass the menu variable, so we'll have a look at how that works next.

Retrieving the menu items

Before we go there, let's see how we can retrieve the menu items in one place instead of doing it per page.

For this, we need to open the _app.js file. Here we can add a function called getInitialProps.

This function can be used to retrieve the menu and eventually pass it to our layout.

import {getPrimaryMenu} from '../lib/api';

MyApp.getInitialProps = async () => {
  const menuItems = await getPrimaryMenu();
  return {menuItems};
};

Passing items to the layout component

Let's see how we can now make sure the layout is used everywhere and pass the menu items.

Let's first add the layout to our _app.js file.

import Layout from '../components/Layout';

function MyApp({Component, pageProps}) {
  return (
    <Layout>
      <Component {...pageProps} />
    </Layout>
  );
}

To access the menu items, we have to add them to the MyApp function.

function MyApp({Component, pageProps, menuItems}) {
  return (
    <Layout menu={menuItems}>
      <Component {...pageProps} />
    </Layout>
  );
}

And with this, we have a fully functional universal layout.

  • _app loads the menu and passes it to our layout component
  • layout works as the main layout and renders the header

If we now run our application, we can see the menu work on all pages automatically.

Creating a reusable layout in Next.js

You can find the complete code on GitHub.

Thank you for reading, and let's connect!

Thank you for reading my blog. Feel free to subscribe to my email newsletter and connect on Facebook or Twitter


This content originally appeared on DEV Community and was authored by Chris Bongers


Print Share Comment Cite Upload Translate Updates
APA

Chris Bongers | Sciencx (2021-09-28T10:46:43+00:00) Creating a reusable layout in Next.js. Retrieved from https://www.scien.cx/2021/09/28/creating-a-reusable-layout-in-next-js/

MLA
" » Creating a reusable layout in Next.js." Chris Bongers | Sciencx - Tuesday September 28, 2021, https://www.scien.cx/2021/09/28/creating-a-reusable-layout-in-next-js/
HARVARD
Chris Bongers | Sciencx Tuesday September 28, 2021 » Creating a reusable layout in Next.js., viewed ,<https://www.scien.cx/2021/09/28/creating-a-reusable-layout-in-next-js/>
VANCOUVER
Chris Bongers | Sciencx - » Creating a reusable layout in Next.js. [Internet]. [Accessed ]. Available from: https://www.scien.cx/2021/09/28/creating-a-reusable-layout-in-next-js/
CHICAGO
" » Creating a reusable layout in Next.js." Chris Bongers | Sciencx - Accessed . https://www.scien.cx/2021/09/28/creating-a-reusable-layout-in-next-js/
IEEE
" » Creating a reusable layout in Next.js." Chris Bongers | Sciencx [Online]. Available: https://www.scien.cx/2021/09/28/creating-a-reusable-layout-in-next-js/. [Accessed: ]
rf:citation
» Creating a reusable layout in Next.js | Chris Bongers | Sciencx | https://www.scien.cx/2021/09/28/creating-a-reusable-layout-in-next-js/ |

Please log in to upload a file.




There are no updates yet.
Click the Upload button above to add an update.

You must be logged in to translate posts. Please log in or register.