zoukankan      html  css  js  c++  java
  • 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

  • 相关阅读:
    代码控制数据流量开关
    用wifi来调试应用程序
    详细解读LruCache类
    修改博客园默认的代码字体大小
    通过Gson解析Json数据
    Docker、Kubernetes的 CICD实现思路
    React中路由传参及接收参数的方式
    微信小程序开发工具调试没问题,真机调试Provisional headers are shown
    物联网卡三码
    【微信开发】-- 企业转账到用户
  • 原文地址:https://www.cnblogs.com/caimuqing/p/7094364.html
Copyright © 2011-2022 走看看