第一步 cnpm install axios
第二步 创建个js文件
import axios from 'axios';
import {ElMessage} from 'element-plus';
import router from "../router";
const ContentType = {
JSON: 'application/json;charset=UTF-8',
FORM: 'application/x-www-form-urlencoded;charset=UTF-8',
UPLOAD: 'multipart/form-data',
STREAM: 'application/octet-stream;charset=UTF-8'
}
axios.defaults.timeout = 5000;
axios.defaults.baseURL = '';
//http request 请求拦截器
axios.interceptors.request.use(
config => {
// const token = getCookie('名称');注意使用的时候需要引入cookie方法,推荐js-cookie
config.data = JSON.stringify(config.data);
config.headers = {
'Content-Type': ContentType.JSON
}
// if(token){
// config.params = {'token':token}
// }
return config;
},
error => {
return Promise.reject(error);
}
);
//http res 响应拦截器
axios.interceptors.response.use(
res => {
console.log(res);
if (res.data.code === 200) {
return res;
} else {
let {code, msg} = res.data
codeHandle(code, msg)
return Promise.reject(res)
}
},
error => {
return Promise.reject(error)
}
)
/**
* 封装get方法
* @param url
* @param data
* @returns {Promise}
*/
export function fetch(url, params = {}) {
return new Promise((resolve, reject) => {
axios.get(url, {
params: params
})
.then(res => {
resolve(res.data);
})
.catch(err => {
reject(err)
})
})
}
/**
* 封装post请求
* @param url
* @param data
* @returns {Promise}
*/
export function post(url, data = {}) {
return new Promise((resolve, reject) => {
axios.post(url, data)
.then(res => {
resolve(res.data);
}, err => {
reject(err)
})
})
}
/**
* 封装patch请求
* @param url
* @param data
* @returns {Promise}
*/
export function patch(url, data = {}) {
return new Promise((resolve, reject) => {
axios.patch(url, data)
.then(res => {
resolve(res.data);
}, err => {
reject(err)
})
})
}
/**
* 封装put请求
* @param url
* @param data
* @returns {Promise}
*/
export function put(url, data = {}) {
return new Promise((resolve, reject) => {
axios.put(url, data)
.then(res => {
resolve(res.data);
}, err => {
reject(err)
})
})
}
/**
* @description: code处理
* @param {number} code
* @param {string} message
*/
const codeHandle = (code, message) => {
console.log(message);
switch (code) {
case 401:
ElMessage.error(message)
router.push({
path: "/login",
query: { redirect: router.currentRoute.fullPath } // 从哪个页面跳转
})
break
default:
ElMessage.error(message)
break
}
}
第三步
import axios from 'axios'
import {post,get,patch,put} from './utils/http'
//定义全局变量
Vue.prototype.$post=post;
Vue.prototype.$get=get;
Vue.prototype.$patch=patch;
Vue.prototype.$put=put;
第四部 这一个主要还是看你的书写习惯,你把所有的接口都放到一个js文件中,这样方便之后接口调试;
export const name = (data) => post(url,data) // 接口备注
也可以在页面直接调用
import {get} from './config/http'
mounted(){
this.$get('/api/v2/movie/top250')
.then((response) => {
console.log(response)
})
},
其余的方法一样