类别:行业新闻 发布时间:2021-01-08 浏览人次:
背景
基于Vue-cli 项目产品部署,涉及到的交互的地址等配置信息,每次都要重新打包才能生效,极大的降低了效率。我们的目的是让项目实施的小伙伴重新快乐起来。网上实现的方式,都是半自动化的,还需要重新修改。
需求点
配置化:打包后的配置文件可二次修改
配置自动生成:vue-cli 提供了各种环境的打包,要实现相关配置文件的自动打包
研发人员无痛感:对于产品研发人员来说,不需要增加额外的打包成本,基于Vue-cli的开发习惯不变。
实现步骤
一:配置自动生成
安装generate-asset-webpack-plugin插件。用于配置文件自动生成。
npm install --save-dev generate-asset-webpack-plugin
配置webpack.prod.conf.js文件.新增如下代码
// 这段代码在配置文件开头 var GenerateAssetPlugin = require('generate-asset-webpack-plugin'); //Add:Strony;Date:2018年12月7日 const env = require('../config/' + process.env.env_config + '.env') // 打包后配置文件:新增 2018年12月7日;Strony var createServerConfig = function (compilation) { //Step1:先复制原对象 var parseEnv = Object.assign({ _hash: compilation.hash}, env) //Step2:去除配置文件中的引号 Object.keys(parseEnv).forEach(function (key) { parseEnv[key] = parseEnv[key].replace(/"/g, ""); return JSON.stringify(parseEnv, null, 2); // 这段代码加在plugins:[]中 new GenerateAssetPlugin({ filename: utils.assetsPath('../static/serverConfig.json'), fn: (compilation, cb) = { cb(null, pilation)); extraFiles: [] })
输入npm run build:prod 打包命令.vue-cli 默认提供了几个环境的打包环境:早期版本直接:npm run build
结果如下:
生成的配置文件样式如下:
"_hash": "52f44b45b5b600b7f36e", "NODE_ENV": "production", "ENV_CONFIG": "sit", "BASE_API": "APIPlateForm/", "BASE_ADDR": "", "REPORT_ADDR": "******" }
二:全局变量从配置文件读取
1.增加serverConfig.json。目的是开发人员本地开发时候,可以从配置文件读取。内容Copy本地的dev.env.js.住里面的格式为json,去除多余的引号。
2.在main.js中添加下面的代码。目的:读取配置地址挂载在全局对象
import axios from 'axios' /* eslint-disable no-new */ // 请求文件内容 function getServerConfig() { return new Promise((resolve, reject) = { axios.get('./static/serverConfig.json').then(result = { console.log(result) const config = result.data; for (const key in config) { Vue.prototype[key] = config[key]; resolve(); // 请求文件内容及创建实例 async function main() { await getServerConfig(); console.log('我的地址是' + Vue.prototype.BASE_API) axios.defaults.baseURL = Vue.prototype.BASE_API;//axios 的基础地址从配置文件读取 new Vue({ el: '#app', router, store, template: ' App/ ', components: { App } // 方法初始执行 main();
3.项目执行:npm run dev。在浏览器的控制台下可以查看到相关的配置信息
4.使用方法:在vue文件中,直接访问使用各类地址信息。
handleWatchLib(linurl) { window.open(this.BASE_ADDR + linurl); return false; }
总结
以上所述是小编给大家介绍的基于Vue-Cli 打包自动生成/抽离相关配置文件的实现方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对凡科网站的支持!
根据Vue-Cli 装包全自动转化成/抽离有关配备文档的完成方式 根据Vue-cli 新项目商品布署,涉及到到的互动的详细地址等配备信息内容,每一次必须再次装包才可以起效,巨大的减少...
2021-01-08手机微信微信小程序完成2个网页页面传值的方式剖析 ,别跑 本文关键详细介绍了手机微信微信小程序完成2个网页页面传值的方式,融合案例方式剖析了手机微信微信小程序URL自动...
2021-01-08招聘人数:8职位信息 我们是一家原创棉麻服饰电商企业,热爱尊重传统文化和非遗,希望通过小伙伴共同的努力,将传统文化创新改良,使它更加适合现代人的穿着体验和生活方式...
2021-01-08JavaScript承继的特点与实践活动运用深层次详细说明 本文关键详细介绍了JavaScript承继的特点与实践活动运用,融合案例方式比较深层次的剖析了javascript承继有关定义、特点、基本原...
2021-01-08针对很多seo工作人员来讲,网站一取得手就盲目跟风开展提升,那样在提升的全过程时会浪费许多時间和活力,太原市红月儿互联网太原市企业网站建设企业觉得,网站的特性提升最大...
2021-01-08手机微信微信小程序完成简易报表 本文关键详细介绍了手机微信微信小程序完成简易报表,具备一定的参照使用价值,很感兴趣的小伙子伴们能够参照一下文中案例为大伙儿共享...
2021-01-08