DEV Community

Cover image for Level Up Your React Skills: Routing and Navigation Made Easy
Sayuj Sehgal
Sayuj Sehgal

Posted on • Originally published at blog.sehgaltech.com

Level Up Your React Skills: Routing and Navigation Made Easy

If you like this blog, you can visit my personal blog sehgaltech for more content.

Welcome back to the React 101 series! In this edition, we’re diving into the world of routing and navigation in React. Building multi-page applications involves seamlessly transitioning between different views and managing URLs. Let’s explore how to achieve this using React Router, a powerful library for handling navigation in React applications.

Understanding the Need for Routing in React

In a single-page application (SPA) built with React, traditional navigation mechanisms don’t apply. Instead of loading entirely new HTML pages, SPAs dynamically update the content based on user interactions. Routing becomes essential to simulate the experience of navigating between multiple pages without triggering a full page reload.

Introducing React Router

React Router is the de facto standard for implementing routing in React applications. It provides a declarative way to define navigation paths, allowing developers to create multi-page experiences within a single-page application. To get started, install React Router using:

npm install react-router-dom
Enter fullscreen mode Exit fullscreen mode

Exploring Key Components:

  • BrowserRouter: Wraps your entire application, enabling routing functionality.

  • Route: Defines a mapping between a URL path and a React component.

  • Link: A component used to navigate between different routes within your application.

Setting Up Basic Routing

  • Router Component: Wrap your application with the BrowserRouter component to enable routing. Place it in the root of your application.
// index.js or App.js
import React from 'react';
import ReactDOM from 'react-dom';
import { BrowserRouter as Router } from 'react-router-dom';
import App from './App';

ReactDOM.render(
  <Router>
    <App />
  </Router>,
  document.getElementById('root')
);

Enter fullscreen mode Exit fullscreen mode
  • Route Component: Use the Route component to define routes. Specify a path and the corresponding component to render when the path is matched.
// App.js
import React from 'react';
import { Route, Switch } from 'react-router-dom';
import Home from './Home';
import About from './About';
import Contact from './Contact';

const App = () => {
  return (
    <div>
      <Switch>
        <Route path="/" exact component={Home} />
        <Route path="/about" component={About} />
        <Route path="/contact" component={Contact} />
      </Switch>
    </div>
  );
};

export default App;

Enter fullscreen mode Exit fullscreen mode
  • Navigation Links: Use the Link component to create navigation links. These links will update the URL and trigger the rendering of the corresponding component.
// Navigation.js
import React from 'react';
import { Link } from 'react-router-dom';

const Navigation = () => {
  return (
    <nav>
      <ul>
        <li><Link to="/">Home</Link></li>
        <li><Link to="/about">About</Link></li>
        <li><Link to="/contact">Contact</Link></li>
      </ul>
    </nav>
  );
};

export default Navigation;

Enter fullscreen mode Exit fullscreen mode

Handling Dynamic Routes

React Router allows for dynamic routes by using parameters in the URL. For example, to create a route that accepts an id parameter:

// App.js
import React from 'react';
import { Route, Switch } from 'react-router-dom';
import Home from './Home';
import About from './About';
import Contact from './Contact';
import UserDetails from './UserDetails';

const App = () => {
  return (
    <div>
      <Switch>
        <Route path="/" exact component={Home} />
        <Route path="/about" component={About} />
        <Route path="/contact" component={Contact} />
        <Route path="/user/:id" component={UserDetails} />
      </Switch>
    </div>
  );
};

export default App;

Enter fullscreen mode Exit fullscreen mode

In this example, accessing a URL like /user/123 would render the UserDetails component with the id parameter set to 123.

Navigating Programmatically

React Router provides a useHistory hook and a history object that can be used to navigate programmatically. For example:

import React from 'react';
import { useHistory } from 'react-router-dom';

const MyComponent = () => {
  const history = useHistory();

  const handleClick = () => {
    // Navigate to the "/new" route
    history.push('/new');
  };

  return (
    <button onClick={handleClick}>Go to New Page</button>
  );
};

Enter fullscreen mode Exit fullscreen mode

Remember:

  • Plan your routes: Define a clear structure for your application before implementing routing.

  • Keep it simple: Start with basic routing concepts and gradually add complexity as needed.

  • Explore further: Dive deeper into React Router documentation and examples to unlock its full potential.

Conclusion

Routing and navigation are crucial aspects of building multi-page applications in React. React Router simplifies the process by providing a robust and declarative way to handle navigation. Whether it’s defining routes, creating dynamic URLs, or navigating programmatically, React Router empowers developers to create seamless and intuitive user experiences within a single-page application. Stay tuned for more insights as we continue our React 101 series!

If you like this blog, you can visit my personal blog sehgaltech for more content.

Top comments (0)