需求:为了代码更好管理和更美观,把axios进行封装了post,get请求,当然所有的请求接口也可以单独用一个js文件进行管理
一、http.js(封装axios得post,get请求,post请求传参得时候要注意,除了qs,传的数组还需要提前JSON.stringify),网上有很多资料关于封装axios,如果你有其他的功能需要,可以搜索进行再一次的封装,更符合自己的需求
import axios from 'axios';
import qs from 'qs';
class Http {
constructor() {
this.axiosInstance = axios.create({timeout: 30000});
}
async get(url, params) {
const res = await this.axiosInstance.get(url, {params:params});
return res.data;
}
/**
* axios post请求
* @param url=服务器地址
* @param params=请求参数
* @param encode = (如需要传送application/x-www-form-urlencoded格式参数,使用qs.stringify转换) 如果参数是数组的形式,传参数的时候先JSON.stringify()转化数组,再传过来
* @param config :object axios得配置
* @returns {Promise<*>}
*/
async post(url, data,config&#