解决不同命令下项目启动和打包到指定的环境
前后端分离的项目开发中,一般都会有开发环境、测试环境、生产环境。
- 开发环境下调试接口的时候,一般都会有好几个接口地址(开发服务器上的,本地的,接口开发人员的,七七八八的接口地址),要根据情况手动来切换接口地址。
- 打包时要部署项目到不同的环境,而这也需要每次都根据情况切换接口地址。
虽说手动来切换地址是可以满足需求的,但是这种方式实属不是一种较为优雅的处理方式。通过修改配置文件,让启动和打包项目时根据不同的命令,可以达到预期的结果。
- 启动项目时,需要修改/config/dev.env.js
– 在/config/dev.env.js中,通过process.argv获取一个命令数组,并为其配置相应的接口地址
'use strict' const merge = require( 'webpack-merge' ) let API_HOST = '' switch (params) { case '--env=test' : break case '--env=prod' : break default: } NODE_ENV: '"development"' , API_HOST: API_HOST }) |
- 打包项目时,需要修改/config/prod.env.js
– 在/config/prod.env.js中,通过process.argv获取一个命令数组,并为其配置相应的接口地址
'use strict' NODE_ENV: '"production"' , } |
- 在/package.json中,为启动命令设置不同的参数
"scripts" : { "dev" : "webpack-dev-server --disableHostCheck=true --inline --progress --config build/webpack.dev.conf.js" , "start" : "npm run dev" , "test" : "npm run unit && npm run e2e" , "lint" : "eslint --ext .js,.vue src test/unit test/e2e/specs" , }, |