为了账号安全,请及时绑定邮箱和手机立即绑定

vue项目webpack配置了不同的开发环境接口地址,axios如何调用

vue项目webpack配置了不同的开发环境接口地址,axios如何调用

阿波罗的战车 2019-02-13 22:17:01
vue-cli生成的项目,config下配置文件分别如下:dev.env.js:'use strict'const merge = require('webpack-merge')const prodEnv = require('./prod.env')module.exports = merge(prodEnv, {  NODE_ENV: '"development"',  API_ROOT: '"//xxx.xxx.xxx.xxx:9001"'})prod.env.js'use strict'module.exports = {  NODE_ENV: '"production"',  API_ROOT: '"https://xxx.zzz.com"'}vue项目配置了不同开发环境的接口地址,axios.defaults.baseURL如何引用这个地址?我在app.vue和main.js中试了以下方法,可以生效,但是因为在配置API_ROOT的时候里面地址带双引号,所以不能直接使用该接口地址,如果去掉API_ROOT中的双引号,打包的时候又会报错。const config = require('../config')import axios from 'axios';if (process.env.NODE_ENV === 'development') {  axios.defaults.baseURL = config.dev.env.API_ROOT;} else {  axios.defaults.baseURL = config.build.env.API_ROOT;}
查看完整描述

1 回答

?
慕尼黑的夜晚无繁华

TA贡献1864条经验 获得超6个赞

一般项目webpack会有两个或多个配置文件,如:

webpack.config.babel.js对应开发环境

webpack.production.config.babel.js对应线上打包


我个人也比较推荐这样配置,而你的axios就没必要去担心baseURL如何引用接口地址

只要使用webpack.DefinePlugin就可以


开发环境(webpack.config.babel.js):


//开发环境下的baseURL

new webpack.DefinePlugin({

  BASE_URL:'xxxxxxxxx'

})

线上环境(webpack.production.config.babel.js):


 //线上环境下的baseURL

new webpack.DefinePlugin({

  BASE_URL:'xxxxxxxxx'

})

你要做的只是在入口文件中写上:axios.defaults.baseURL = BASE_URL;即可


查看完整回答
反对 回复 2019-02-16
  • 1 回答
  • 0 关注
  • 1211 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信