key concepts of react router with examples
Here are some key concepts and examples to help you understand React Router better
BrowserRouter: React Router provides different router types. The BrowserRouter
is the most commonly used router. It uses HTML5 history API to keep your UI in sync with the URL. Here's an example of how to use it:
import { BrowserRouter as Router, Route, Link } from 'react-router-dom';
function App() {
return (
<Router>
<div>
<nav>
<ul>
<li>
<Link to="/">Home</Link>
</li>
<li>
<Link to="/about">About</Link>
</li>
</ul>
</nav>
<Route path="/" exact component={Home} />
<Route path="/about" component={About} />
</div>
</Router>
);
}
function Home() {
return <h1>Home Page</h1>;
}
function About() {
return <h1>About Page</h1>;
}
Route: The Route
component is used to define a mapping between a URL path and a corresponding component to render. It takes a path
prop to specify the URL path and a component
prop to specify the component to render when the path matches. Here's an example:
<Route path="/about" component={About} />
Link: The Link
component is used to create a hyperlink to navigate between different routes. It renders an <a>
tag with the specified destination. Here's an example:
<Link to="/about">About</Link>
Switch: The Switch
component is used to render only the first Route
or Redirect
that matches the current location. It helps to ensure that only one route is rendered at a time. Here's an example:
import { Switch, Route } from 'react-router-dom';
// ...
<Switch>
<Route path="/" exact component={Home} />
<Route path="/about" component={About} />
<Route path="/contact" component={Contact} />
</Switch>
Nested Routes: React Router allows you to nest routes by rendering child components within parent components. Here's an example:
function App() {
return (
<Router>
<div>
<Route path="/" exact component={Home} />
<Route path="/products" component={Products} />
</div>
</Router>
);
}
function Products({ match }) {
return (
<div>
<h1>Products</h1>
<ul>
<li>
<Link to={`${match.url}/1`}>Product 1</Link>
</li>
<li>
<Link to={`${match.url}/2`}>Product 2</Link>
</li>
</ul>
<Route path={`${match.path}/:productId`} component={ProductDetails} />
</div>
);
}
function ProductDetails({ match }) {
const productId = match.params.productId;
// Fetch product details using productId
return <h2>Product {productId} Details</h2>;
}
URL Parameters: React Router allows you to define dynamic segments in your URL paths using colon (:
) notation. These dynamic segments can be accessed as parameters in your component. Here's an example:
<Route path="/users/:userId" component={UserDetails} />
// ...
function UserDetails({ match }) {
const userId = match.params.userId;
// Fetch user details using userId
return <h2>User Details for ID: {userId}</h2>;
}
These are some essential concepts to get you started with React Router. There are many more features and functionalities available, such as query parameters, redirects, and route guards. I encourage you to explore the React Router documentation for a comprehensive understanding: reactrouter.com/web/guides/quick-start