通常服务器分为本地环境,测试环境,正式环境
若是每次都要修改配置就很麻烦,总结一下我使用的方法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 ̄)づ╭❤~
转载请联系做者!