webpack打包 生成JOSN格式配置文件 dist根目录生成

大家在日常开发上线,上预发,测试环境的时候,一定遇到过不同环境,配置项不同的情况,比如不同的环境部署的代码一致,只有Host需要配置不同。这个时候,如果每次都要重新修改代码,不仅显得不专业,也容易在提交的时候忘记这个配置,提交错误就是上线灾难。所以,有必要在打包后的文件中生成配置文件,供在外部修改配置。本篇就是为了解决这个问题而写~~

这要用到一个webpack插件generate-asset-webpack-plugin

Install

npm install --save-dev generate-asset-webpack-plugin

在webpack.prod.cong.js中引入该插件

const GeneraterAssetPlugin = require('generate-asset-webpack-plugin')

在项目根目录下建立配置文件serverConfig.json
内部配置为{"baseUrl":""}
将该配置文件引入

const serverConfig = require('../serverConfig.json')

将Json中的配置项返回

 
  1. const createJson = function(compilation) {

  2. return JSON.stringify(serverConfig)

  3. }

在webpackConfig -> plugin中写入

 
  1. new GeneraterAssetPlugin({

  2. filename: 'serverConfig.json',//输出到dist根目录下的serverConfig.json文件,名字可以按需改

  3. fn: (compilation, cb) => {

  4. cb(null, createJson(compilation));

  5. }

  6. })

在引入axios的文件中做如下配置

 
  1. axios.get('serverConfig.json').then((result) => {

  2. window.localStorage['JSON_HOST'] = result.data.baseUrl

  3. }).catch((error) => { console.log(error) });

利用localStorage存储JSON_HOST配置值,需要取时再取出JSON_HOST,再将需要配置host的地方写成

host: window.localStorage['JSON_HOST']

打包后在根目录就会生成如下dist文件

clipboard.png


外部就可以通过修改该配置文件,变更host了

clipboard.png

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值