此文档主要为4步代码组成
通过这篇博文你能学到:
one:怎么配置外部变量避免重复打包,
two:生产环境和开发环境共用一个接口文件,不用创建三个文件index.js,index_dev.js,index_pro.js
three:开发环境跨域配置
开始:
1.index.html,引入外部变量配置文件(paramConfig.js),此文件在第二步会创建
<script src="/static/paramConfig.js"></script>
2.static目录放创建外部变量配置文件,为什么是static目录呢?因为这个目录的资源不会被打包,保持原态
window.paramConfig = {
"api": "网址1",
"examapi": "网址2",
"recuiteapi": "网址3"
};
3.src目录下面创建config目录,放置axios接口配置文档index.js,
代码解释:
first part:import部分不管,各有作用;就是引入要用到的各种包和自己的文件
second part:判断环境变量,开发环境需要proxy跨域,生产环境的接口地址为第二步定义的相关地址
third part:axios相关的一些配置,详情请参考axios官网http://www.axios-js.com/zh-cn/docs/#%E6%8B%A6%E6%88%AA%E5%99%A8
fourth part:导出vue页面的js要引用的一些接口
部分代码如下
import Axios from 'axios'
import Qs from 'qs'
import md5 from 'js-md5';
import abbr from '@api/abbr'
import store from '../store'
//baseApi examBaseApi recuiteBaseApi
let baseApi, examBaseApi, recuiteBaseApi;
let curEnv = process.env.NODE_ENV;
if(curEnv === 'development'){
baseApi = '/api';
examBaseApi = '/examapi';
recuiteBaseApi = '/recuiteapi';
}else{
baseApi = paramConfig.api;
examBaseApi = paramConfig.examapi;
recuiteBaseApi = paramConfig.recuiteapi;
}
var instance = Axios.create({
headers: {
'content-type': 'application/x-www-form-urlencoded',
'Access-Control-Allow-Origin': '*',
'Access-Control-Allow-Credentials': true
}
});
// 添加请求拦截器
instance.interceptors.request.use(function (config) {
// 在发送请求之前做些什么
return config;
}, function (error) {
// 对请求错误做些什么
return Promise.reject(error);
});
// 添加响应拦截器
instance.interceptors.response.use(function (response) {
// 对响应数据做点什么
if(response.data.code == abbr.errorLoginId){
store.commit('setLoginOut');
return;
}else{
return response;
}
}, function (error) {
// 对响应错误做点什么
return Promise.reject(error);
});
export default instance;
//获取个人信息接口
export const apiGetUserObj = params => {
return new Promise((resolve, reject) => {
instance.post(
baseApi+'/user/findStudent',
Qs.stringify({
stuId: params.id,
})
)
.then(response => {
resolve(response.data)
})
.catch(error => {
reject(error)
})
})
}
4.开发环境跨域配置:修改config目录下面的index.js导出的dev部分的proxyTable
proxyTable: {
"/api":{
target: 'http://www.baidu.com',
changeOrigin: true,
pathRewrite: {
'^/api': '/'
}
},
"/examapi":{
target: 'http://www.sina.com',
// target: 'http://192.168.1.109',
changeOrigin: true,
pathRewrite: {
'^/examapi': '/'
}
},
"/recuiteapi":{
target: 'http://www.tb.com',
changeOrigin: true,
pathRewrite: {
'^/recuiteapi': '/'
}
}
},