全局配置axios可提升代码可维护性,也可以进行统一配置请求头信息和拦截器等
一、创建配置axios的文件
比如我创建的名为:ajax.js文件
二、创建并暴露axios实例配置请求头信息
import axios from 'axios'
//全局配置axios可提升代码可维护性
//创建axios对象,并暴露对象,可以对外部访问
//创建对象时对其进行头信息设置及加载上次携带的cookie
export const ajax=axios.create({headers:{source:'h5','Content_Type':'application/x-www-form-urlencoded'},withCredentials:true //携带cookie
})
source: 'h5'
:是用来标识请求来源,比如这里表示请求来自 H5 页面。
'Content_Type': 'application/x-www-form-urlencoded'
:设置请求的内容类型为 application/x-www-form-urlencoded
,这是表单数据提交的一种编码类型,表示发送的数据将按照键值对的方式编码。
通过设置 withCredentials: true
,确保跨域请求时携带 cookie。这对于需要维护会话状态的前端应用很重要。
三、统一配置拦截器
1、请求拦截器
ajax.interceptors.request.use((req)=>{console.log('请求拦截到了')return req},(err)=>{return Promise.reject(err)}
)
interceptors是拦截器关键字,request是代表是请求拦截器。第一个参数是正确时执行的函数,第二个是出错时执行的函数。
2、响应拦截器
ajax.interceptors.response.use((resp)=>{console.log('响应拦截到了')return resp
},(err)=>{if(err.response.status==401){alert('未登录,即将跳转至未登录页面')}return Promise.reject(err)
})
跟请求拦截器不同的是interceptors打点调用的是response,代表是响应拦截器。也可以对错误进行一些逻辑判断,如上述代码实现了当状态码是401时弹出提示框提示:未登录。。。。
这样当在别的文件中使用暴露的ajax常量进行发起请求和处理响应了,用ajax发起的请求响应就已经配置好了头信息和拦截器,而不用单独配置。
四、案例:
onMounted(()=>{//axios用于进行异步提交的工具,可以向服务器发起请求,获取服务端响应的数据ajax.get('https://www.baidu.com').then(resp=>{console.log('返回的结果:',resp)}).catch(err=>{console.log('请求出错:',err)})
})