vue多環境配置方案

前言

通常服務器分爲本地環境,測試環境,正式環境
若是每次都要修改配置就很麻煩,總結一下我使用的方法html

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能跨平臺地設置及使用環境變量,使用vue

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一下node

dev.env.jswebpack

'use strict'
module.exports = {
  NODE_ENV: '"development"',
  ENV_CONFIG: '"dev"'
}

prod.env.jsgit

'use strict'
module.exports = {
  NODE_ENV: '"production"',
  ENV_CONFIG: '"prod"'
}

sit.env.jsgithub

'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')web

vue默認是兩個配置,一個是dev,一個prod,修改webpack.prod.conf.js後就能夠判斷是測試環境仍是正式環境了npm

// const env = require('../config/prod.env')
const env = require('../config/' + process.env.env_config + '.env')

應用

在src文件夾裏新建config文件夾,裏面新建index.jsjson

index.jsapi

'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)

稍後會將demo上傳到github上

關於我

您能夠掃描添加下方的微信並備註 Soul 加交流羣,給我提意見,交流學習。

圖片描述

若是對你有幫助送我一顆小星星(づ ̄3 ̄)づ╭❤~

轉載請聯繫做者!

相關文章
相關標籤/搜索