在线体验 axios-series 功能 Edit in CodeSandbox
# 使用pnpm
$ pnpm install axios-series
# 使用npm
$ npm install axios-series --save
import axios from 'axios'
import wrapper from 'axios-series'
const axiosSeries = wrapper(axios, {
// unique: false,
// orderly: true
})
export default axiosSeries
import axios from 'axios'
import wrapper from 'axios-series'
const instance = axios.create({
withCredentials: true
})
const axiosSeries = wrapper(instance, {
// unique: false,
// orderly: true
})
export default axiosSeries
serializer 的配置
参数 | 描述 | 类型 | 可选值 | 是否必填 | 默认值 |
---|---|---|---|---|---|
unique | make request unique, clear all similar requests | boolean |
true/false | false | false |
orderly | resolve results orderly | boolean |
true/false | false | true |
onCancel | callback function for cancel requests | (err: any, config: InternalAxiosRequestConfig): void |
- | false | null |
当向同一个接口(url 一致但 data 可以不一样)同时(或者间隔很短时间)发起多次请求时,可能用户只需要最后一次的请求结果,当 unique
设置为 true
时,前面的请求会被取消
神奇的是:当向同一个接口同时发起多次请求时,axiosSerios 并不是死板地等待上一个接口返回之后才开始请求。所有的请求都是同时发起的,所以 axiosSerios 对于网页性能是没有损失的
-
版本:
1.0.0
-
展示:
// |
// |
axiosSeries({ url: '/api/1' }); axiosSeries({ url: '/api/1' }); | axiosSeries({ url: '/api/1' });
// \___________/ \___________/ | \___________/
// | | | |
// request 1 request 2 | When request 3 start, 1 & 2 will be cancelled
// |
- 示例:
- 向 /test/api/1 (data 可以不一样)同时(或者间隔很短时间)发起 3 次请求
. 设置
unique
为true
// 请求 1
axiosSeries({
url: '/test/api/1',
data: { id: 1 }
})
// 请求 2
axiosSeries({
url: '/test/api/1',
data: { id: 2 }
})
// 请求1会被取消
当同时(或者间隔很短时间)向同一个接口(url 一致但 data 可以不一样)请求多次,由于网络原因无法保证先执行的请求先返回结果,这个 orderly
参数就是用来解决这个问题的。当orderly
设置为 true 时,先请求的一定会先于后请求的先返回结果
-
版本:
1.0.0
-
Show:
// -> | -> | ->
// | |
axiosSeries({ url: '/api/1' }); | axiosSeries({ url: '/api/1' }); | axiosSeries({ url: '/api/1' });
// \___________/ | \___________/ | \___________/
// | | | | |
// request 1 | request 2 will wait for | request 3 will wait for
// | request 1 before returning | request 1 & 2 before returning
// | |
- 示例:
- 向 /test/api/1 (data 可以不一样)同时(或者间隔很短时间)发起 3 次请求
. 设置
orderly
为 true
// 请求 1
axiosSeries({
url: '/test/api/1',
data: { id: 1 }
})
// 请求 2
axiosSeries({
url: '/test/api/1',
data: { id: 2 }
})
// 请求1一定会先于请求2返回结果
axios serializer 包装器
-
版本:
1.0.0
-
参数:
参数 | 描述 | 类型 | 可选值 | 是否必填 | 默认值 |
---|---|---|---|---|---|
instance | axios or axios instance | AxiosInstance |
axios/axiosInstance | true | - |
options | serializer options | SerializerOptions |
- | false | - |
-
返回: 返回带 serializer 的 axios 实例
-
示例:
const http = axiosSeries(instance, {
// unique: false,
// orderly: true
})
- 类型:
function axiosWithSeries<T = any, R = AxiosResponse<T>, D = any>(
config: SerializerRequestOptions<D>
): Promise<R>
function axiosWithSeries<T = any, R = AxiosResponse<T>, D = any>(
url: string,
config?: SerializerRequestOptions<D>
): Promise<R>
清理所有的请求队列
-
版本:
1.0.0
-
参数:
none
-
返回: 'none'
-
示例:
const http = axiosSeries(instance, {})
http.clear()
- 类型:
type clear = () => void
所有的请求队列
-
版本:
1.0.0
-
参数:
none
-
返回: 'WaitingList'
-
示例:
const http = axiosSeries(instance, {})
console.log(http.series) // []
- 类型:
declare interface Series {
promiseKey: symbol
promise: Promise<any>
source: CancelTokenSource
abortController?: AbortController
}
declare type WaitingList = Record<string, Series[]>
<script src="https://unpkg.com/browse/axios@1.4.0/dist/axios.min.js"></script>
<script src="https://unpkg.com/axios-series@1.0.0/dist/index.global.prod.js"></script>
<script>
const http = axiosSeries(axios)
</script>
Please open an issue here.