VUE 利用webpack 给生产环境和发布环境配置不同的接口地址
第一步,分别设置不同的接口地址
首先,我们分别找到下面的文件:
/config/dev.env.js
/config/prod.env.js
其实,这两个文件就是针对生产环境和发布环境设置不同参数的文件。我们打开dev.en.js文件。代码如下:
var merge = require('webpack-merge') var prodEnv = require('./prod.env') module.exports = merge(prodEnv, { NODE_ENV: '"development"' })
我们在NODE_ENV下面增加一项,代码如下:
var merge = require('webpack-merge') var prodEnv = require('./prod.env') module.exports = merge(prodEnv, { NODE_ENV: '"development"', API_ROOT: '"//192.168.1.8/api"' })
prod.env.js文件修改为:
module.exports = { NODE_ENV: '"production"', API_ROOT: '"//www.baidu.com/api"' }
第二步,在代码中调用设置好的参数
以我们之前的演示代码为例。你自己的项目请根据你自己的情况调整。以下文件和代码仅供参考。
我们打开src/config/api.js文件,将原来开头的代码
// 配置API接口地址 var root = 'https://cnodejs.org/api/v1'
修改为:
// 配置API接口地址 var root = process.env.API_ROOT
然后就完成了我们的配置工作。最后,重启项目,就能使新配置的接口地址生效了。
npm run dev
npm run build
在main.js区分生产与开发环境
process.env.NODE_ENV == 'production'; //生产环境 process.env.NODE_ENV == 'development'; //开发环境