While there are different libraries available for client-side routing, React Router is almost always the default choice.
Why React Router?
As the user navigates, the browser keeps track of each location in a stack. That is how the back and forward buttons work.
For example, consider the user:
- Clicks a link to
/blog
- Clicks a link to
/categories
- Clicks the back button
- Clicks a link to
/contact
The history stack will change as follows,
where the highlighted
entries denote the current URL.
/blog
/blog
,/categories
/blog
,/categories
/blog
,/contact
If we click and hold the back button in a browser, we can see the browser’s history stack right there.
Now, some of us might argue that we don’t necessarily need a library to manipulate the history stack. We can do that programmatically like so:
While the above code changes the URL.
It doesn’t do anything about the UI.
We will still need to subscribe
to the changes in the history stack
to show the correct UI on /blog
.
Read more about browser’s History API.
React Router makes it easier for us to subscribe to the changes in the browser’s history stack. It also allows us to manipulate the history stack.
Navigation
React Router provides us with an easy-to-use interface for navigation.
We can use:
<Link>
and<NavLink>
, which renders an<a>
element. We can initiate navigation by clicking on it.useNavigate
and<Navigate>
which will enable us to navigate programmatically.
Let us look at <Link>
and <NavLink>
and their usage.
We can use <NavLink>
in the above example instead of <Link>
.
The difference between the two is that <NavLink>
knows whether or not it is “active”.
So if we want to apply some styles to the active link,
we need to use <NavLink>
.
Now, consider a scenario where
we want to navigate our users to /dashboard
after they successfully log in.
This is exactly the place where
we would want to navigate programmatically.
React Router provides us useNavigate
and <Navigate>
to do exactly that.
Let us see how we can use them:
Alternatively, we can also use <Navigate>
like this:
With this, we do not have to worry about manipulating the history stack and subscribing to its changes. React Router handles all of that for us!
React Router 6 provides a few low-level APIs that can be useful while building our navigation interfaces -
Check out the React Router 6 API doc to learn more.