To create a toggle menu component with React Router in a React application, you can follow these steps. We'll use React, React Router, and some basic CSS for styling:
1. Install necessary dependencies if you haven't already:
```bash
npm install react react-dom react-router-dom
```
2. Create a `ToggleMenu` component:
```jsx
// ToggleMenu.js
import React, { useState } from 'react';
import { Link } from 'react-router-dom';
const ToggleMenu = () => {
const [menuOpen, setMenuOpen] = useState(false);
const toggleMenu = () => {
setMenuOpen(!menuOpen);
};
return (
<div className={`toggle-menu ${menuOpen ? 'open' : ''}`}>
<button className="menu-toggle-button" onClick={toggleMenu}>
Menu
</button>
<ul className="menu-list">
<li>
<Link to="/">Home</Link>
</li>
<li>
<Link to="/about">About</Link>
</li>
<li>
<Link to="/contact">Contact</Link>
</li>
</ul>
</div>
);
};
export default ToggleMenu;
```
3. Style your `ToggleMenu` component using CSS or a CSS-in-JS solution like Styled Components.
```css
/* styles.css */
.toggle-menu {
position: relative;
}
.menu-toggle-button {
background: #333;
color: #fff;
border: none;
padding: 10px 20px;
cursor: pointer;
}
.menu-list {
list-style: none;
padding: 0;
position: absolute;
top: 50px;
left: 0;
background: #333;
color: #fff;
transform: scaleY(0);
transform-origin: top;
transition: transform 0.3s ease-in-out;
}
.menu-list.open {
transform: scaleY(1);
}
.menu-list li {
padding: 10px;
border-bottom: 1px solid #666;
}
.menu-list a {
text-decoration: none;
color: #fff;
}
```
4. Use the `ToggleMenu` component in your application. You can place it in a common layout or specific route components where you want to display the toggle menu.
```jsx
// App.js
import React from 'react';
import { BrowserRouter as Router, Route, Switch } from 'react-router-dom';
import ToggleMenu from './ToggleMenu';
import Home from './Home';
import About from './About';
import Contact from './Contact';
const App = () => {
return (
<Router>
<ToggleMenu />
<Switch>
<Route path="/" exact component={Home} />
<Route path="/about" component={About} />
<Route path="/contact" component={Contact} />
</Switch>
</Router>
);
};
export default App;
```
Now, you have a toggle menu component that works with React Router. When you click the "Menu" button, it will display the menu links, and you can navigate between different routes in your application. Customize the styling and content of the `ToggleMenu` component to fit your project's needs.