vue-配置外部网址变量--避免重复打包

此文档主要为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': '/'
				}
			}
		},

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章