axios-cache-interceptor/docs/pages/usage-examples.md
Arthur Fiorette 7293cf0c26
feat!: new bundle setup & fixed development bundles (#167)
* feat: added issue template

* fix: move dev bundles to a specific folder

* docs: some documentation changes

* docs: updated issue template

* chore!: updated build setup

* style: formatted code

* chore: allow importing any file
2022-03-11 13:46:08 -03:00

3.9 KiB

Usage and Examples

There are some other examples in the [examples](https://, check them out! You can also make a PR to add some more.

Applying

This library is based on axios interceptors, so, under the hood, it uses axios.interceptors.use() to apply the interceptors. But you don't. All you have to do is call setupCache and you are ready to go!

import { setupCache } from 'axios-cache-interceptor';

setupCache(axios);

How to get the axios instance

There are two types of axios instances, the AxiosStatic and the AxiosInstance. The AxiosStatic is the default instance of axios. The AxiosInstance is the instance you get when you call axios.create().

Both of them work seamlessly, but when messing with the axios static, your hole code, including those libraries you don't even know that they exists, are also affected. You should be careful when using it.

// AxiosStatic
import axios from 'axios';

// AxiosInstance
const instance = axios.create();

Customizing behaviors

You can customize the behaviors of this library in two ways, in a per request or in a global way.

const Axios = require('axios');
const { setupCache } = require('axios-cache-interceptor');

const instance = Axios.create({
  /** Here you can pass the axios options * */
});

// Global options
setupCache(instance, {
  /** Here you can pass the interceptor options * */
});

// Per request options
const result = await instance.get('https://jsonplaceholder.typicode.com/posts/1', {
  /** Override axios options * */
  cache: {
    /** Override cache options * */
  }
});

console.log('Result:', result.data);

Nodejs server example

An NodeJS with ExpressJS example to return data from another api.

const express = require('express');
const app = express();

const Axios = require('axios');
const { setupCache } = require('axios-cache-interceptor');

const api = setupCache(
  Axios.create({ baseURL: 'https://jsonplaceholder.typicode.com/' }),
  // 5 seconds
  { ttl: 5 * 1000 }
);

// Every time an api call reaches here, it will
// make another internal request and forward the response.
app.get('/', (req, res) => {
  api.get('/users').then(
    ({ data, cached, id }) => {
      res.json({
        cached,
        id: {
          value: id,
          deleteUrl: `/cache/${id}/delete`,
          getUrl: `/cache/${id}/get`
        },
        data
      });
    },
    (error) => {
      res.json({ error });
    }
  );
});

app.get('/cache/:id/delete', async (req, res) => {
  await api.storage.remove(req.params.id);
  res.send({
    status: 'Deleted!',
    current: await api.storage.get(req.params.id)
  });
});

app.get('/cache/:id/get', async (req, res) => {
  const cache = await api.storage.get(req.params.id);
  res.json(cache);
});

app.listen(3000);

Jsx component example

You shouldn't store cache in state libraries, it even is a bad practice. And even if you do so, you probably will have to write a lot of code to handle cache invalidation, strategies and etc.

With this library, you can just call any axios method without worrying about requesting thousands of times for every component draw. Simple as that!

function Component() {
  // React component state (but can be from any other framework, library and etc)
  const [data, setData] = useState(null);

  // Calling this function every component redraw does not have any
  // problems, as the response is cached in the first request. This
  // even work with concurrent requests and for many components at
  // the same time
  axios.get('https://api.example.com').then((response) => {
    setData(response.data);
  });

  return (
    <div class=":)">
      <div>{data}</div>
    </div>
  );
}