How To Use Axios in an Optimized and Scalable Way With React

We can see how to use Axios in an optimized and scalable way in a React app.

When you are building an API-based React app, an HTTP client is the core service that needs to be added to the architecture. There are many HTTP client libraries for React. W…


This content originally appeared on DEV Community and was authored by Nilanth

We can see how to use Axios in an optimized and scalable way in a React app.

When you are building an API-based React app, an HTTP client is the core service that needs to be added to the architecture. There are many HTTP client libraries for React. When deciding which to choose, Axios might be the first choice of most developers.

Axios is an HTTP client library with many advantage features. It can be used in browsers and Node.js. In this article, we will see how to utilize all the advanced Axios features in a scalable and optimized way.

Axios Instance

Creating an Axios instance is more important for a large-scale app, as all the base configuration lies in a single file. A change in the base config can be done easily in a single file and will be reflected anywhere the Axios instance is used. Check out the below code snippet

Based on the above code, we have configured all the base setup using default config, which will be applied to every request which uses the axiosClient instance, as shown in the below request.

Axios Verbs

We can group the Axios HTTP verbs, like GET, POST, DELETE, and PATCH, in the base config file, as below.

Now we can import the custom functions directly wherever we need to make an API request, as in the below code.

Timeout

The Axios timeout option allows setting the request timeout in milliseconds. It is easy to configure timeout in Axios. It can be defined in the base config itself, as we saw before.

timeout: 2000 // Request will be timeout after 2 seconds.

Intercept Request

Using a request intercept, you can write or execute before it is sent. Check out the below code snippet.

Here we have added the contentType header before the request is made. Request interceptors are asynchronous by default, which might cause some delay in Axios request execution. To avoid this, we have used synchronous: true.

Intercept Response

Using Request intercept you can write or execute before the response reaches then. Response interceptors can be used to log out the user on token expiry (401 status) or you can refresh the token and make the failed request again to make the user stay on the same page, for good UX.

Upload Progress

You can track upload progress in Axios very easily using the onUploadProgress option. onUploadProgress allows handling of progress events for uploads. This can be used to show the upload percentage live to the user, to acknowledge to them the upload is in progress. Check out the below code.

Resources

Axios GitHub repository

Conclusion

Axios is a great HTTP client package for React and its community. I hope you have found this useful. Thank you for reading.

Need to learn more? Feel free to connect on Twitter.


This content originally appeared on DEV Community and was authored by Nilanth


Print Share Comment Cite Upload Translate Updates
APA

Nilanth | Sciencx (2021-07-14T14:22:46+00:00) How To Use Axios in an Optimized and Scalable Way With React. Retrieved from https://www.scien.cx/2021/07/14/how-to-use-axios-in-an-optimized-and-scalable-way-with-react/

MLA
" » How To Use Axios in an Optimized and Scalable Way With React." Nilanth | Sciencx - Wednesday July 14, 2021, https://www.scien.cx/2021/07/14/how-to-use-axios-in-an-optimized-and-scalable-way-with-react/
HARVARD
Nilanth | Sciencx Wednesday July 14, 2021 » How To Use Axios in an Optimized and Scalable Way With React., viewed ,<https://www.scien.cx/2021/07/14/how-to-use-axios-in-an-optimized-and-scalable-way-with-react/>
VANCOUVER
Nilanth | Sciencx - » How To Use Axios in an Optimized and Scalable Way With React. [Internet]. [Accessed ]. Available from: https://www.scien.cx/2021/07/14/how-to-use-axios-in-an-optimized-and-scalable-way-with-react/
CHICAGO
" » How To Use Axios in an Optimized and Scalable Way With React." Nilanth | Sciencx - Accessed . https://www.scien.cx/2021/07/14/how-to-use-axios-in-an-optimized-and-scalable-way-with-react/
IEEE
" » How To Use Axios in an Optimized and Scalable Way With React." Nilanth | Sciencx [Online]. Available: https://www.scien.cx/2021/07/14/how-to-use-axios-in-an-optimized-and-scalable-way-with-react/. [Accessed: ]
rf:citation
» How To Use Axios in an Optimized and Scalable Way With React | Nilanth | Sciencx | https://www.scien.cx/2021/07/14/how-to-use-axios-in-an-optimized-and-scalable-way-with-react/ |

Please log in to upload a file.




There are no updates yet.
Click the Upload button above to add an update.

You must be logged in to translate posts. Please log in or register.