How to Create a Responsive Horizontal Menu with Antd Component Library

Jacob Naryan - Full-Stack Developer

Posted: Sat Aug 05 2023

Last updated: Wed Nov 22 2023

In this tutorial, we will learn how to create a responsive horizontal menu using the Antd component library. Antd is a React UI library that provides a range of high-quality components out of the box. It is incredibly easy to use and provides a clean and modern look to your application. Let’s get started!

1. Prerequisites

Before beginning this tutorial, you should have React installed and have basic familiarity with the Antd component library. You should also make sure you have an up-to-date version of Node.js installed on your system.

2. Setup

In order to get started, you should create a new React application by running the following command in your terminal:

npx create-react-app my-app

Once your application has been created, you should navigate into the directory and install the Antd library by running the command:

npm install antd

3. Create the Menu Component

Once you have the Antd library installed, you can begin creating the menu component by creating a new file called Menu.js in your src directory. In this file, we will import the Menu component from Antd and define our menu items.

import React from 'react'; 
import { Menu } from 'antd';

const MenuItems = [
{ name: 'Home', link: '/home' },
{ name: 'About', link: '/about' },
{ name: 'Contact', link: '/contact' }
];

const MyMenu = () => {

return (
<Menu mode="horizontal">

{MenuItems.map(item => (

<Menu.Item key={item.name}>

<a href={item.link}>{item.name}</a>

</Menu.Item>

))}

</Menu>

);

};

export default MyMenu;

In this code snippet, we are importing the Menu component from Antd and creating an array of menu items that we want to display in our menu. We then define our MyMenu component which uses the Menu component from Antd in order to render our menu items. We are also setting the mode prop of the Menu component to horizontal, which will ensure that our menu is displayed horizontally across the page. Finally, we export our MyMenu component so that it can be used in other parts of our application.

4. Add the Menu Component to App.js

Now that we have our MyMenu component defined, we need to add it to our main App component in order for it to be displayed on our page. To do this, open up your App.js file and import the MyMenu component at the top of the file:

import MyMenu from './components/menu';

Next, we need to add the MyMenu component to our App component's render method as shown below:

class App extends Component {  

render() {

return (

<div className="App">

<MyMenu />

{/* Other components here */}

</div>

);

}
}

Now if you save your changes and run your application, you should see your newly created horizontal menu displayed on your page! Congratulations! You have now successfully created a responsive horizontal menu using the Antd component library!

💡 Note: Once you’ve built this responsive horizonal menu, it might be a good idea to isolate and extract this component into packages, so you can use an open-source toolchain like Bit to publish, version, and reuse it across all of your projects with a simple npm i @bit/your-username/MyMenu. Find out more here, and here.

Thank you for reading. If you liked this blog, check out my personal blog for more content like this.

Need a developer?

Hire me  for all your Web Development needs.