Cache Mode
The cache mode can be set at different granularities such as global or request level. When set globally, all Method instances created from the same alova instance will inherit the setting.
Whether to use the cache mode and which cache mode to use depends on the scenario. The usage scenarios of different cache modes will be mentioned below when introducing different cache modes separately.
Memory mode (default)
The memory mode puts the cache in the memory, which means that the page cache is invalidated when it is refreshed, and is the most commonly used cache mode.
Memory mode is generally used to solve the performance consumption caused by frequent requests for the same data in a short period of time (minutes or seconds). For example, when you are writing a todo details page, you may think that users will frequently click on the todo list Check the details, if the user does not repeatedly request the interface when repeatedly viewing a certain detail, and can return the data immediately, the colleague who improves the response speed also reduces the pressure on the server. At this point we can set the response data cache for a todo detail Method
instance.
alovaInstance.GET('/todo/list', {
//...
localCache: {
// Set cache mode to memory mode
mode: 'memory',
// unit is milliseconds
// When set to `Infinity`, it means that the data will never expire, and when it is set to 0 or a negative number, it means no caching
expire: 60 * 10 * 1000
}
});
Memory mode is the default mode, you can abbreviate like this
alovaInstance.GET('/todo/list', {
//...
localCache: 60 * 10 * 1000
});
GET requests will set the memory cache time of 300000ms (5 minutes) by default, and developers can also customize the settings.
If you need to set the caching mode globally, see [Global setting cache mode] at the bottom of this section (#Global setting cache mode)
Memory mode example
Cache placeholder mode
This cache mode is used when you don't want to display the Loading icon every time the application is entered, but you want to use the old data instead, you can use the cache occupancy mode, which has a better experience than Loading.
In the cache occupancy mode, data
will be immediately assigned the old data of the last cache. You can judge that if there is old data, use it to replace the Loading display. At the same time, it will send a request to obtain the latest data and update the cache, so as to achieve In order to quickly display the actual data, and obtain the latest data.
Set on Method
instances:
const todoListGetter = alovaInstance.Get('/todo/list', {
//...
localCache: {
// Set the cache mode to persistent placeholder mode
mode: 'placeholder',
// cache time
expire: 60 * 10 * 1000
}
});
If you need to set the caching mode globally, see [Global setting cache mode] at the bottom of this section (#Global setting cache mode)
Cache placeholder mode example
Restore mode
In this mode, the server-side cached data will be persistent. If the expiration time is not reached, even if the page cache is refreshed, it will not be invalidated. It is generally used for some data that requires server-side management but is basically unchanged, such as the specific dates of annual holidays. It is different, but it will not change again. In this scenario, we only need to set the cache expiration time to the last moment of this year.
Set on Method
instances:
const todoListGetter = alovaInstance.Get('/todo/list', {
//...
localCache: {
// Set the cache mode to persistent mode
mode: 'restore',
// cache time
expire: 60 * 10 * 1000
}
});
When request body is special data such as FormData, Blob, ArrayBuffer, URLSearchParams, ReadableStream, it will be considered that you intend to communicate with server. In this case would not cache data.
If you need to set the caching mode globally, see [Global setting cache mode] at the bottom of this section (#Global setting cache mode)
Restore mode example
What should I do if the data changes in restore mode?
When the Method
instance in restore mode is set, it may be due to the change of the interface data or the logic change of the front-end processing response data. At this time, it is necessary to let the user re-cache the changed data after publishing the application. At this time, you can use tag
The attribute sets the cache tag. Each piece of persistent data contains a tag
identifier. When the tag
changes, the original persistent data will become invalid, and new data will be obtained again, and the new tag
will be used for identification .
const todoListGetter = alovaInstance.Get('/todo/list', {
//...
localCache: {
mode: 'restore',
expire: 60 * 10 * 1000,
// Add or modify the tag parameter, the cached data will be invalid
// It is recommended to use version number management
tag: 'v1'
}
});
Global setting cache mode
v1.3.0+
The above settings are all set separately on Method
. If you need to set the cache mode globally, you can do it as follows:
const alovaInstance = createAlova({
//...
localCache: {
// Uniformly set the cache mode of POST
POST: {
mode: 'placeholder',
expire: 60 * 10 * 1000
},
// Uniformly set the cache mode of the HEAD request
HEAD: 60 * 10 * 1000
}
});
Henceforth, the Method
instance created by alovaInstance
instance will use this cache setting by default, and it can also be overridden in the Method
instance.
Note: When the cache mode is set globally, the original 5-minute GET cache mode will be overwritten.
Disable caching mode globally
If you don't want to use any request cache in your project, you can turn it off globally. If you want to use it only in a few specific requests, you can also turn it off globally and set it in the specified Method
instance .
const alovaInstance = createAlova({
//...
// Set to null to disable all request caching globally
localCache: null
});
Expiration time type
There are two types of expiration time to choose from, namely relative time and absolute time
Relative Time
That is, the time to expire when the cached data is saved, in milliseconds, the above examples are all of this type.
localCache: 60 * 10 * 1000;
localCache: {
expire: 60 * 10 * 1000,
}
absolute time
With a specific time point as the expiration time, the cache will expire at the set time point
localCache: new Date('2030-01-01');
localCache: {
expire: new Date('2030-01-01');
}
Instruction for response automatic maintenance
The key of the response data cache is uniquely identified by the combination of the request method (method), request address (url), request header parameters (headers), url parameters (params), and request body parameters (requestBody) of the method instance. Any information or Different positions will be treated as different keys.
Note that the key of the response data cache (or method) is only determined when the method created. After the method instance is created, modifying any of the following: request method (method), request address (url), request header parameters (headers), url parameters (params), or request body parameters (requestBody) will not cause the key to change, which will result in the cache pointing to the same value.
In this case, if you need to cache separately pointing to different values, consider dynamically creating methods.
const alovaInst = createAlova({
// ...
beforeRequest(method) {
const sec = Math.floor(Date.now() / 1000);
method.config.headers.sec = sec;
}
});
const Getter = () =>
alovaInst.Get('/user/profile', {
// ...
localCache: 10 * 1000
});
// create a new method
Getter().send();
// or
useRequest(Getter);