**发送get请求演示**
import axios from 'axios'
export default {
name:'app',
created(){ //在vue的生命周期函数中
//提问:为什么没有跨域的问题?
//1.没有请求参数
axios.get('http://123.207.32.32:8000/api/v1')
.then(res=>{
console.log(res);
}).catch(err=>{
console.log(err)
})
//2.有参数
axios.get('http://123.207.32.32:8000/api/v1',
{params:{type:'sell',page:1}})
.then(res=>{
console.log(res)
}).catch(err=>{
console.log(err)
})
}
}
**发送并发请求**
created(){ //在vue的生命周期函数中
axios.all([axios.get('http://123.207.32.32:8000/api'),
axios.get('http://123.207.32.32:8000/api')],
{params:{type:'sell',page:1}})
.then(axios.spread((res1,res2)=>{
console.log(res1);
console.log(res2);
}))
}
//提取全局的配置
axios.defaults.baseURL = 'http://123.207.32.32:8000'
//发送并请求
axios.all([axios.get('/api'),
axios.get('/home'),
{params:{type:'sell',page:1}}])
.then(axios.spread((res1,res2)={
console.log(res1);
console.log(res2);
}))
//创建新的实例
const axiosInstance =axios.create({
baseURL:'http://123.207.32.32:8000',
timeout:5000,
headers:{
'Content-Type':'application/x-www.from-urlencoded'
}
//发送网络请求
axiosInstance({
url:'/api',
method:'get',
}).then(res=>{
console.log(res);
}).catch(err=>{
console.log(err);
})
})
//创建的axios文件中
import originAxios from 'axios'
export default function axios(option){
return new Promise((resolve,reject)={
//1.创建axios实例
const instance = originAxios.create({
baseURL:'/api',
timeout:5000,
headers:''
});
//2.传入的对象进行网络请求(optiond)
instance(option).then(res=>{
resolve(res);
}).catch(err=>{
reject(err);
})
//对第二步的简写(因为axios本身返回的就是一个Promise)
//去掉export下面return Promise的那一行
return instance(config)
})
}
**请求拦截**
instance.interceptors.request.use(config=>{
console.log('来到了request拦截的success中')
// 1.当发送网络请求时,在页面中添加了一个loading组件,作为动画
// 2. 某些请求要求用户必须登陆,判断用户是否有token,如果没有token跳转到login页面
// 3.对请求的参数进行序列化
config.data =qs.stringify(config.data)
console.log(config)
//当拦截完了一定要记得将拦截返回
return config
})
use()中还有一个err参数,表示请求错误后的拦截,请求拦截中错误拦截比较少,通常都是配置相关的拦截,可能的错误比如请求超时时,可以将页面跳转到一个错误的页面中
**响应拦截**
响应的成功拦截中,主要是对数据进行过滤
instance.interceptors.response.use(response=>{
console.log("来到了response拦截success中");
return response.data
响应失败的拦截中,可以根据status判断报错的错误码,跳转到不同的错误提示页面
},err => {
console.log('来到了response拦截的failure中')
if( err && err.response){
switch(err.response.status){
case 400:
err.message = '请求错误',
break;
case 401:
err.message = '未授权的访问',
break;
}
}
return err
})
原文:https://www.cnblogs.com/JCDXH/p/11716959.html