useAxios
React-Hook to use Axios easy way.
Notice
useAxios is custom React-Hook; So it works on only React environment.
Installation
$ npm install @sooni-hooks/use-axios
- Add
import useAxios from "@sooni-hooks/use-axios"
in your script. - Done!
How to use
useAxios has two parameters.
-
opts: Config to
axios
-
axiosInstance: A request method. If you don't give any argument, default instance is
axios
.
useAxios returns an object containing state
and refetch()
.
-
state: An object containing
loading
,error
,data
.-
loading: Default value is
true
. When fetching is completed, It changes tofalse
. - error: The error message.
- data: The data that you want to get.
-
loading: Default value is
- refetch() A function that retries fetching data from URL.
If you want to get more information about Axios
, go to this link:
https://www.npmjs.com/package/axios
Example code
function App() {
const options = {
url: "https://jsonplaceholder.typicode.com/todos/1", // example url
};
const { loading, error, data, refetch } = useAxios(options);
return (
<div className="App">
<h1>{JSON.stringify(loading)}</h1>
<p>{JSON.stringify(error)}</p>
<p>{JSON.stringify(data)}</p>
<button onClick={refetch}></button>
</div>
);
}
Full code
import { useEffect, useState } from "react";
import defaultAxios from "axios";
const useAxios = (opts, axiosInstance = defaultAxios) => {
const [state, setState] = useState({
loading: true,
error: null,
data: null,
});
const [trigger, setTrigger] = useState(0);
if (!opts.url) {
return;
}
const refetch = () => {
setState({
...state,
loading: true,
});
setTrigger(Date.now());
};
useEffect(() => {
axiosInstance(opts)
.then((data) => {
setState({
...state,
loading: false,
data,
});
})
.catch((error) => {
setState({ ...state, loading: false, error });
});
}, [trigger]);
return { ...state, refetch };
};
export default useAxios;