
前言
一般伺服器分為本地環境,測試環境,正式環境,如果每次都要修改配置就很麻煩,總結一下我使用的方法。
vue-demo/
|-build/
|-config/
|-dist/
|-src/
|-config/
|-index.js
|-dev.conf.js
|-sit.conf.js
|-prod.conf.js
|-package.json
|-index.html
修改執行指令
修改package.json檔案的scripts,在打包的時候執行不同的指令
測試執行那npm run build:sit
正式執行npm run build:prod
這裡用到了cross-env能跨平台地設定及使用環境變量,使用
npm install cross-env --save
"scripts": {
"dev": "webpack-dev-server --inline --progress --config build/webpack.dev.conf.js",
"start": "npm run dev",
"build": "node build/build.js",
"build:prod": "cross-env NODE_ENV=production env_config=prod node build/build.js",
"build:sit": "cross-env NODE_ENV=production env_config=sit node build/build.js"
},
修改配置檔案
修改vue項目下config檔案夾裡的dev.env.js和prod.env.js,添加sit.env.js檔案,分别對應本地,正式和測試的配置檔案。
這裡需要強調一下,如果這幾個檔案修改了一定要重新npm run dev一下。
dev.env.js
'use strict'
module.exports = {
NODE_ENV: '"development"',
ENV_CONFIG: '"dev"'
}
prod.env.js
'use strict'
module.exports = {
NODE_ENV: '"production"',
ENV_CONFIG: '"prod"'
}
sit.env.js
'use strict'
module.exports = {
NODE_ENV: '"production"',
ENV_CONFIG: '"sit"'
}
修改build下的webpack.prod.conf.js檔案找到const env = require('../config/prod.env')
修改成const env = require('../config/' + process.env.env_config + '.env')
vue預設是兩個配置,一個是dev,一個prod,修改webpack.prod.conf.js後就可以判斷是測試環境還是正式環境了。
// const env = require('../config/prod.env')
const env = require('../config/' + process.env.env_config + '.env')
應用
在src檔案夾裡建立config檔案夾,裡面建立index.js
index.js
'use strict'
// 根據環境引入不同配置 process.env.ENV_CONFIG ex:dev.conf.js
const config = require('./' + process.env.ENV_CONFIG + '.conf')
module.exports = config
dev.conf.js,sit.conf.js,prod.conf.js三個檔案夾裡寫不同的配置。
// 配置本地測試
module.exports = {
/*
* action 七牛上傳位址
* bucket 空間名
* domain 回顯域名
*/
qiniu: {
action: 'https://up.qiniup.com',
bucket: 'xxx',
domain: 'xxx'
},
// 接口位址配置
baseURL: 'https://localhost/api/v1'
}
最後
直接使用就可以了。
import { qiniu } from '@/config/index.js'
console.log(qiniu.action)
學習更多技能
請點選下方公衆号