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

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;
}
阅读 5k
评论
    2 个回答
    • 1.8k

    一般项目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;即可

      • 3
      • 新人请关照

      配置了全局baseUrl后,开发环境无法跨域,这是错误信息:
      已拦截跨源请求:同源策略禁止读取位于 http://localhost:8090/.../api/index/itemList 的远程资源。(原因:CORS 头缺少 'Access-Control-Allow-Origin')。
      Error: Network Error
      就是控制台没有任何输出,提示上面的错误,但是看网络请求却又是成功的。然后注释掉baseUrl配置后都成功了。这个是什么问题呢

        撰写回答

        登录后参与交流、获取后续更新提醒