1. 程式人生 > 其它 >vue多環境配置

vue多環境配置

Vue多環境配置方案的實現

一般伺服器分為本地環境,測試環境,正式環境,如果每次都要修改配置就很麻煩,總結一下我使用的方法。

修改執行命令

修改package.json檔案的scripts,在打包的時候執行不同的命令

測試執行那npmrun build:sit
正式執行npmrun 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檔案找到constenv = require('../config/prod.env')
修改成constenv = 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)