16.如何做到webpack打包vue项目后,可以修改配置文件
2021-07-09 09:06
标签:更新 span 打包 key ons err bpa creat 问题 问题描述: 前端需要修改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插件 在webpack.prod.conf.js里面配置 打包之后,在根目录就会生成serverconfig.json文件 使用: 则可以获取到serverconfig.json里面的key ApiUrl的值,需要注意的是,由于是异步操作,为了通信,可以采用localstorage,把东西存起来,即localstorage.setItem 使用的时候可以用localstorage.getItem 16.如何做到webpack打包vue项目后,可以修改配置文件 标签:更新 span 打包 key ons err bpa creat 问题 原文地址:http://www.cnblogs.com/caimuqing/p/7094364.htmlnpm install --save-dev generate-asset-webpack-plugin
//让打包的时候输出可配置的文件
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: []
})
axios.get("serverconfig.json").then((result)=>{
localStorage.setItem(‘ApiUrl‘,result.data.ApiUrl);
console.log(localStorage.getItem(‘ApiUrl‘));
}).catch((error)=>{console.log(error)});
上一篇:网站笔记
下一篇:CSS3 阴影模拟灯照效果
文章标题:16.如何做到webpack打包vue项目后,可以修改配置文件
文章链接:http://soscw.com/essay/102717.html