22
Client-Side Routing in React
On this blog post, I would like to share a general overview of the concept of client-side routing that I have learned through the React phase. It was very helpful to use React tools in one project to understand the hierarchy of the components as well as nested children.
Client-side routing comes into place when building a single-page-application to separate its components onto different pages based on the endpoint of the URL of each page. The client-side routing is the internal handling of a route inside the Javascript file that is rendered to the client; without making additional Get requests for new HTML documents other than the initial and only Get request.
The major benefit of client-side routing is speed. Since the client-side code is responsible for routing, fetching, and displaying data in the browser, the client side router swaps the components in response to the user clicks.
The limitations of client-side routing consist of:
- It takes a while to load all the CSS and Javascript on the initial GET especially if the application size is large.
- It is hard to track page views via analytic tools.
- Single-page applications are complicated design wise compare to multi-page applications.
React Router is the client-side library that enables two major features:
- Conditional rendering of components based on the endpoint of the URL.
- Programmatic navigation that updates the content of the page without making new GET requests.
The first step to start using React Router is to install react-router-dom in the terminal: <$npm install react-router-dom>.Then, import Browser Router from react-router-dom in index.js file:
Next, import Route from react-router-dom in the parent component "App":
We use a Switch component to give the routes more predictive behavior. The Switch component is also imported from react-router-dom:
Now that we define our routes, we can manipulate them via the address bar; but there are more efficient ways to achieve that via other tools such as Link and NavLink provided by the React Library.
The NavLink renders an anchor tag < a > to the dom and is used as a navigation bar with built in and customizable styling. NavLink should be placed outside and above the switch component so it can be accessed and displayed in all the pages. An example of NavLink component:
Similarly to NavLink, Link also renders an anchor tag < a > to the dom. Link can be used within the application pages as buttons with links that takes you to specific routes. Example of Links:
Note that routes are following RESTful conventions.
React modular applications are perfect tool for displaying lists of items. Going back to the example of list of cars (see code snippets above), the user should be able to click a car card and be directed to car details. Since, we are fetching the data using a db-json server and each car in the list has its own unique id, we can use useParams() method to get dynamic params from the URLs and therefore display the correct item.
First, we have to import useParams() method from react-router-dom.
Next, we have to assign the useParams() method to a variable inside our ItemDetails (i.e. CarDetails) component.
The id variable can be used then to fetch that specific item:
The purpose of programmatic navigation is to direct the user to different pages without the need to click on a link. For instance, when the user submit a form (a new item) and need to be directed to the list of items to see the newly created item displayed in the original list. Another example is when we perform a delete action and we need to direct the user back to the main list. One way to achieve that is via useHistory Hook.
Fisrt, we import the useHistory Hook from react-router-dom.
Then, assign it to a variable:
Here is an example of Patch request of a form submit action where the user is directed to the main list after submitting the new item:
Here is another example of Delete request where the user will be directed to the main list of cars after deleting the a specific item (car):
This was a general overview of the concept of client-side routing with some useful hooks from the react router library.
22