本文代码中的配置基于vue-cli2vue
在实际开发中咱们可能有测试环境一套请求API 和 正式环境一套API,尤为是两个环境的域名不一样时,就须要咱们分环境打不一样配置的包node
DefinePlugin 此插件能够在打包时定义环境变量,在开发时咱们也能在代码中获取定义的环境变量。webpack
用法:ios
plugins: [
new webpack.DefinePlugin({
'process.env.mode': '"development"'
})
...
]
复制代码
plugins: [
new webpack.DefinePlugin({
'process.env': {
NODE_ENV: '"development"',
EVN_CONFIG: '"dev"',
API_ROOT: '"dev API_ROOT"'
}
})
...
]
复制代码
plugins: [
new webpack.DefinePlugin({
'process.env': require('../config/dev.env')
})
...
]
复制代码
// /config/dev.env.js
'use strict'
const merge = require('webpack-merge')
const prodEnv = require('./prod.env')
module.exports = merge(prodEnv, {
NODE_ENV: '"development"',
EVN_CONFIG: '"dev"',
API_ROOT: '"dev API_ROOT"'
})
复制代码
在vue-cli2 中/build/webpack.dev.conf.js
文件引用了 /config/dev.env.js
文件的配置做为环境变量,所以咱们执行npm run dev
时(执行/build/webpack.dev.conf.js
)就能够在咱们开发代码中得到环境变量(console.log(process.env)
试一试)web
而后咱们观察/build/webpack.prod.conf.js
(npm run build时执行)vue-cli
// /build/webpack.prod.conf.js
const env = require('../config/prod.env')
...
new webpack.DefinePlugin({
'process.env': env
}),
复制代码
可见打包时使用的是/build/webpack.prod.conf.js
文件配置做为环境变量npm
cross-env
npm install --save-dev cross-env
json
cross-env 统一了不一样操做系统设置环境变量的方式. 用法:axios
"scripts": {
"build": "node build/build.js",
"build:test": "cross-env NODE_ENV=production env_config=test node build/build.js", //设置了环境变量 NODE_ENV 和 env_config
"build:prod": "cross-env NODE_ENV=production env_config=prod node build/build.js", //设置了环境变量 NODE_ENV 和 env_config
}
复制代码
由上面分析,咱们获得,要分环境打包,咱们针对不一样的环境去配置不一样的环境变量就能够了。api
// package.json
"scripts": {
"dev": "webpack-dev-server --inline --progress --config build/webpack.dev.conf.js",
"start": "npm run dev",
"build": "node build/build.js",
"build:test": "cross-env NODE_ENV=production env_config=test node build/build.js",
"build:prod": "cross-env NODE_ENV=production env_config=prod node build/build.js"
},
复制代码
咱们设置了两个环境变量 NODE_ENV
和 env_config
而后执行正常的打包。这里的环境变量设置是方便咱们在webpack配置文件中使用
新建 在/config
目录下新建test.env.js
文件存放test的环境变量
// /config/test.env.js
'use strict'
module.exports = {
NODE_ENV: '"testing"',
EVN_CONFIG:'"test"',
API_ROOT:'"/test/apis/v1"'
}
复制代码
我门注释掉
//const env = require('../config/prod.env')
复制代码
修改为
//const env = require('../config/prod.env')
const env_config = process.env.env_config || ''; //执行不一样的打包脚本对应不一样的env_config值
switch (env_config){
case 'test':
var env= require('../config/test.env');
break;
case 'prod':
var env= require('../config/prod.env');
break;
default:
var env= require('../config/prod.env');
}
...
复制代码
// Home.vue
axios.get(process.env.API_ROOT) ...
复制代码
webpack 提供一个很是有用的配置,该配置能帮助你为项目中的全部资源指定一个基础路径。它被称为公共路径(publicPath)
咱们修改webpack中的 publicPath 来让资源引用地址改成cdn 观察vue-cli我门发现publicPath写在了 /config/index.js
文件的build对象中,因此咱们修改以下
...
const testCDN = 'https://testcdn.com';
const prodCDN = 'https://prodcdn.com';
build: {
assetsPublicPath: process.env.env_config=='test'?testCDN:prodCDN
}
复制代码
也能够将cdn地址统一写在上文中的环境配置文件中
var prodEnv = require('./prod.env');
var testEnv = require('./test.env');
...
build: {
assetsPublicPath: process.env.env_config=='test'?testEnv.FILE_CDN:prodEnv.FILE_CDN,
}
复制代码
总体思路就是建不一样的打包脚本,而后根据不一样的打包脚本,应用相应的环境变量配置文件