React Router: How to Create a Custom Back Button

Updated: March 2, 2023 By: Snowball Post a comment

This practical article shows you how to implement a custom back button in a React application that uses React Router 6 (the latest version). Besides the browser’s back button, our custom back button will add convenience and optimize the user experience.

A Quick Note

In React Router 6, we can navigate programmatically by using the useNavigate hook. To go back to the previous route, you can do as follows:

const navigate = useNavigate();
navigate(-1);

If you want to go back more than one page, replace -1 with -2, -3, etc. Now it’s time to see some real code.

The Example

Preview

The small demo project we’re going to make has 2 pages:

  • Home page: This page presents a link that leads the user to the about page
  • About page: This contains a blue button that can be used to go back to the home page

Here’s how it works:

The Steps

1. Create a new brand new React project:

npx create-react-app kindacode-example

2. Install React Router:

npm i react-router-dom

3. In your src/App.js file, remove all of the default code and add the following (you can find the detailed explanations in the comments):

// KindaCode.com
// src/App.js
import {
  BrowserRouter,
  Routes,
  Route,
  Link,
  useNavigate,
} from 'react-router-dom';
import './App.css';

// App component
function App() {
  return (
    <BrowserRouter>
      <Routes>
        <Route path='/' element={<HomePage />} />
        <Route path='/about' element={<AboutPage />} />
      </Routes>
    </BrowserRouter>
  );
}

// Home page
const HomePage = () => {
  return (
    <div className='container'>
      <h1>KindaCode.com - Home Page</h1>
      {/* Use this link to go to the About page */}
      <Link to='/about'>Go to About page</Link>
    </div>
  );
};

// About page
const AboutPage = () => {
  // Use this hook to programmatically navigate to another page
  const navigate = useNavigate();

  // This function is used to navigate to the home page
  // It will be called when the button is clicked
  const goBack = () => {
    navigate(-1);
  };

  return (
    <div className='container'>
      {/* Here's our custom back button */}
      <button onClick={goBack} className='back-button'>
        &larr; Go Back
      </button>
      <h1>About Page</h1>
      <p>
        To go to the home page, you can use either the <b>blue back button</b>{' '}
        or the back button of the browser
      </p>
    </div>
  );
};

export default App;

4. An important part of our project is CSS. Replace the unwanted code in your src/App.css with this:

.container {
    width: 80%;
    margin: 30px auto;
}

.back-button {
    padding: 10px 30px;
    background: #2196f3;
    color: #fff;
    font-weight: bold;
    border: none;
    border-radius: 5px;
    cursor: pointer;
    transition: 0.5s;
}

.back-button:hover {
    background: #0d47a1;
}

5. Run it and check the result:

npm start

Conclusion

You’ve learned how to make a custom back button with React Router 6. If the browser’s back button is out of our control, our custom back button can be placed anywhere on the page as long as it makes sense.

If you’d like to explore more new and interesting things about modern React and React Router, take a look at the following articles:

You can also check our React category page and React Native category page for the latest tutorials and examples.

Related Articles