axios 多个请求拦截器的执行顺序和响应拦截器的执行顺序

axios 多个请求拦截器的执行顺序和响应拦截器的执行顺序_第1张图片

axios chains数组来保存请求拦截器和ajax请求以及相应拦截器的方法,但是对于请求拦截器是用unshift传入到chains中的,对响应拦截器采用unshift例如
request.hanlders.forEach(item=>chains.unshift(item))
对于response拦截器来说是push
response.hanlders.forEach(item=>chains.push(item))
调用的时候也是用chains
while(chains.length>0){

promise    =    promise.then(chain.shift(),chain.shift())

}
return promise

从上面来讲就能知道为什么 请求拦截器是倒序执行的,响应拦截器是正序执行的
请求拦截器1 = {fullied,reject}
请求拦截器2 = {fullied,reject}
响应拦截器1 = {fullied,reject}
响应拦截器2 = {fullied,reject}
chains = [请求拦截器1,请求拦截器2,dispatchRequest,undefined,响应拦截器1,响应拦截器2]
该文章只为自己记录学习使用

你可能感兴趣的:(axios 多个请求拦截器的执行顺序和响应拦截器的执行顺序)