Vue中的Interceptor可以攔截請(qǐng)求和響應(yīng),提供了靈活的機(jī)制來修改請(qǐng)求和響應(yīng)配置。這是在Vue通訊過程中非常實(shí)用的技巧,在編寫復(fù)雜的請(qǐng)求和響應(yīng)處理邏輯時(shí)可以很方便地在請(qǐng)求前或響應(yīng)后深入定制請(qǐng)求和響應(yīng)的配置。
在Vue中使用Interceptor,我們需要在axios上設(shè)置一下interceptor,可以在Vue的app.js中或者其他文件中設(shè)置一個(gè)默認(rèn)攔截器,也可以為每一個(gè)請(qǐng)求設(shè)置一個(gè)獨(dú)立的攔截器。
const app = new Vue({ el: '#app', data: { ... }, mounted () { axios.interceptors.request.use((config) =>{ // 在請(qǐng)求發(fā)送之前做一些處理 return config; }, (error) =>{ // 對(duì)請(qǐng)求錯(cuò)誤做些什么 return Promise.reject(error); }); axios.interceptors.response.use((response) =>{ // 對(duì)響應(yīng)數(shù)據(jù)做些事情 return response; }, (error) =>{ // 對(duì)響應(yīng)錯(cuò)誤做些什么 return Promise.reject(error); }); } });
在以上的代碼中,我們首先使用了axios.interceptors.request.use來設(shè)置一個(gè)請(qǐng)求攔截器,然后使用axios.interceptors.response.use設(shè)置了一個(gè)響應(yīng)攔截器。
使用攔截器的好處在于我們可以在請(qǐng)求和響應(yīng)處理前后做很多操作,比如在請(qǐng)求發(fā)送之前加入一些header,或者在響應(yīng)返回之后加入一些驗(yàn)證邏輯等等。在Vue中使用攔截器,可以輕松地完成這些操作。