现在有个项目打包的时候静态资源的地址是写死线上的,因此在测试环境的时候访问不到静态资源。
因此就想通过命令行来控制打包时的地址,例如npm run build --env=box1
,然后通过argv拿到传入的env参数
const args = process.argv.splice(2);
let env = ''
args.map(item=>{
let params = item.split('=');
if(params[0] == 'env') {
env = params[1]
}
})
module.exports = {
DEV: 'dev',
PRODUCT: 'product',
SERVER_URL: `https://static${env ? '-' + env: ''}.xxxx.com/xxx/`//静态资源地址
}
结果args中没有我要的env=box1,因此只能在每次打包的时候手动把env加在cli里,但是这样很容易忘记
因此,请问有没有办法获取env=box1
这个参数呢?
`npm run build --env=box1`
`npm run build --env=box2`
...
`npm run build --env=qc1`
`npm run build --env=qc2`
...
这里是webpack官方的方案,直传即可:https://webpack.js.org/guides...