axios

axios封装拦截器

Axios 是一个基于 promise 的 HTTP 库,可以用在浏览器和 node.js 中。很多情况我们要对请求和其响应进行特定的处理;如果请求数非常多,单独对每一个请求进行处理会变得非常麻烦。axios为开发者提供了这样一个API:拦截器。拦截器分为 请求(request)拦截器响应(response)拦截器

示例

  • 创建一个axios实例
const serve = axios.create({
  baseURL: process.env.BASE_URL,  // api的基本url,也可以直接写定好的url
  timeout: 5000  // 请求超时时间
});
  • 请求拦截器
serve.interceptors.request.use(config => {    
  config.method === 'post'        
      ? config.data = qs.stringify({...config.data})        
      : config.params = {...config.params};    
	config.headers['Content-Type'] = 'application/x-www-form-urlencoded'; 
  return config;
}, error => {  //请求错误处理   
   Promise.reject(error)
});
  • 响应拦截器
serve.interceptors.response.use(    
  response => {  //成功请求到数据
	//这里根据后端提供的数据进行对应的处理        
  if (response.data.result === 'TRUE') {            
	  return response.data;        
	} else { 
		//打印错误信息
		console.error(response.data.data.msg) 
  }    
}, error => {  //响应错误处理console.log('error');        
		console.error(error);        
		console.error(JSON.stringify(error));         
    let text = JSON.parse(JSON.stringify(error)).response.status === 404            
       ? '404'            
       : '网络异常,请重试';        
     alert(text)        
     return Promise.reject(error)   
});
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值