webpack+vue打包之后输出配置文件修改接口文件
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了webpack+vue打包之后输出配置文件修改接口文件相关的知识,希望对你有一定的参考价值。
参考技术A用vue-cli构建的项目通常是采用前后端分离的开发模式,也就是前端与后台完全分离,此时就需要将后台接口地址打包进项目中,but,难道我们只是改个接口地址也要重新打包吗?当然不行了,那就太麻烦了,怎么解决呢?其实方法很多,接下来我推荐一种最便捷的方法,也是最容易操作的方法。
引用: https://blog.csdn.net/xiaojun_yuan/article/details/79460484
16.如何做到webpack打包vue项目后,可以修改配置文件
问题描述:
前端需要修改restful API的url,但是打包之后,配置文件找不到了,如果在npm run build 生成dist后,这个配置也被写死了,传到运行的前端服务器上后,假设某次,api服务器的ip修改了,改动只是更新下这个url,但是却需要会到前端源码,url后,在重新npm run build,然后再把整个dist再重新传到前端服务器,才可以。
解决方法:
用了generate-asset-webpack-plugin 这个插件,在webpack.prod.conf.js中去生成configServer.json文件,让其在build的时候生成json文件,然后再使用axios异步获取json,替换url即可
具体做法:
先安装generate-asset-webpack-plugin插件
npm install --save-dev generate-asset-webpack-plugin
在webpack.prod.conf.js里面配置
//让打包的时候输出可配置的文件 var GenerateAssetPlugin = require(\'generate-asset-webpack-plugin\'); var createServerConfig = function(compilation){ let cfgJson={ApiUrl:"http://139.129.31.108:8001"}; return JSON.stringify(cfgJson); }
//让打包的时候输入可配置的文件 new GenerateAssetPlugin({ filename: \'serverconfig.json\', fn: (compilation, cb) => { cb(null, createServerConfig(compilation)); }, extraFiles: [] })
打包之后,在根目录就会生成serverconfig.json文件
使用:
axios.get("serverconfig.json").then((result)=>{ localStorage.setItem(\'ApiUrl\',result.data.ApiUrl); console.log(localStorage.getItem(\'ApiUrl\')); }).catch((error)=>{console.log(error)});
则可以获取到serverconfig.json里面的key ApiUrl的值,需要注意的是,由于是异步操作,为了通信,可以采用localstorage,把东西存起来,即localstorage.setItem
使用的时候可以用localstorage.getItem
以上是关于webpack+vue打包之后输出配置文件修改接口文件的主要内容,如果未能解决你的问题,请参考以下文章