基于vue-cli搭建多模块且各模块独立打包的项目


Posted in Javascript onJune 12, 2019

如果我们在开发系统A时,能够按模块划分生成多份静态资源包,最终的成果物中,会有多个子目录,每个子目录可独立运行,完成一个业务功能。这样的话,我们有任何系统需要我们开发过的任何模块,都可以直接打包指定的模块,灵活组装。

优点:

1、可与其他系统灵活组装

2、各个模块相互不受影响,所以不受框架和开发模式的制约

 3、不同模块可以分开部署

4、后期维护风险小,可以持续的、稳定的进行维护

 缺点:

1、各个模块有相互独立的资源包,那么如果有相同的资源引用,不能复用

2、模块的组装要依赖iframe,所以要对浏览器安全设置、cookie共享等问题进行单独处理

3、用iframe来包裹组件,组件所能控制到的范围就是其所在的iframe,当涉及到全屏的应用场景时,会比较麻烦

4、不同组件之间的通信比较麻烦 实现目标

vue-cli默认打包方式的成果物:

基于vue-cli搭建多模块且各模块独立打包的项目

修改配置后生成的成果物结构:

基于vue-cli搭建多模块且各模块独立打包的项目 

思路

由于我们现在的项目是多模块的,每个模块都应该有独立的入口,所以我们修改src目录结构如下:

基于vue-cli搭建多模块且各模块独立打包的项目

注意:原来的src下的main.js、index.html和app.vue已经没用了,可以删掉

然后模块内的目录结构如下图所示:

基于vue-cli搭建多模块且各模块独立打包的项目

注意:

这里跟原来的src下的main.js、index.html和app.vue一样的,只不过我们把main.js改成了index.js而已。 至于模块内要使用路由、状态管理都可以根据自己的需求去配置了。

以下是修改webpack配置的详细步骤

第一步:增加build/module-conf.js用来处理获取模块目录等问题

第二步:增加build/build-all.js用来处理循环执行打包命令

第三步:修改build/build.js增加MODULE_ENV参数,用来记录当前打包的模块名称,增加MODE_ENV参数,用来记录当前打包的模式

第四步:修改config/index.js的配置,修改打包时的出口目录配置、html入口模板的配置以及静态资源路径配置

第五步:修改webpack.base.conf.js的入口配置,根据传参,动态配置入口文件

第六步:修改webpack.dev.conf.js的配置,增加多入口时webpackHtmlPlugin插件的配置,增加静态资源服务器的配置

第七步:修改webpack.prod.conf.js的配置,增加对不同打包模式的处理。

第八步:修改package.json,增加npm run build-all指令 构建指令 打包全部模块到一个资源包下面,每个模块的入口是module.html文件,静态资源都在static目录中,这种方式可以复用重复的资源

npm run build

打包指定模块到一个资源包下面,每个模块的入口是module.html文件,静态资源都在static目录中,这种方式可以复用重复的资源

npm run build moduleName1,moduleName2,...

打包所有模块,然后每个模块彼此独立,有几个模块,就产生几个静态资源包,这种方式不会复用重复的资源

npm run build-all

总结

以上所述是小编给大家介绍的基于vue-cli搭建多模块且各模块独立打包的项目,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

Javascript 相关文章推荐
js异或加解密效果代码
Jun 25 Javascript
基于jquery的direction图片渐变动画效果
May 24 Javascript
利用javascript的面向对象的特性实现限制试用期
Aug 04 Javascript
jQuery 下拉列表 二级联动插件分享
Mar 29 Javascript
bootstrap中使用google prettify让代码高亮的方法
Oct 21 Javascript
JavaScript仿聊天室聊天记录
Dec 27 Javascript
vue.js之vue-cli脚手架的搭建详解
May 05 Javascript
vue: WebStorm设置快速编译运行的方法
Oct 18 Javascript
如何在Vue中使用CleaveJS格式化你的输入内容
Dec 14 Javascript
js实现金山打字通小游戏
Jul 24 Javascript
Vue.js使用axios动态获取response里的data数据操作
Sep 08 Javascript
JS模拟实现京东快递单号查询
Nov 30 Javascript
浅谈webpack 四个核心概念之Entry
Jun 12 #Javascript
vue安装遇到的5个报错及解决方法
Jun 12 #Javascript
深入学习JavaScript 高阶函数
Jun 11 #Javascript
javascript防抖函数debounce详解
Jun 11 #Javascript
详解ng-alain动态表单SF表单项设置必填和正则校验
Jun 11 #Javascript
vue实现路由懒加载及组件懒加载的方式
Jun 11 #Javascript
Vue+element 解决浏览器自动填充记住的账号密码问题
Jun 11 #Javascript
You might like
php的正则处理函数总结分析
2008/06/20 PHP
DedeCMS dede_channeltype表字段注释
2010/04/07 PHP
php随机输出名人名言的代码
2012/10/07 PHP
PHP解耦的三重境界(浅谈服务容器)
2017/03/13 PHP
php5.6.x到php7.0.x特性小结
2019/08/17 PHP
PHP并发场景的三种解决方案代码实例
2021/02/27 PHP
javascript生成/解析dom的CDATA类型的字段的代码
2007/04/22 Javascript
一些Javascript的IE和Firefox(火狐)兼容性的问题总结及常用例子
2009/05/21 Javascript
IE6下focus与blur错乱的解决方案
2011/07/31 Javascript
JS分页效果示例
2013/10/11 Javascript
Bootstrap3下拉菜单的实现
2017/02/22 Javascript
原生JS+Canvas实现五子棋游戏实例
2017/06/19 Javascript
JavaScript 中使用 Generator的方法
2017/12/29 Javascript
微信小程序实现人脸检测功能
2018/05/25 Javascript
Vue中使用 setTimeout() setInterval()函数的问题
2018/09/13 Javascript
React实现全局组件的Toast轻提示效果
2018/09/21 Javascript
Echarts地图添加引导线效果(labelLine)
2019/09/30 Javascript
JavaScript实现移动端弹窗后禁止滚动
2020/05/25 Javascript
Python实现SMTP发送邮件详细教程
2021/03/02 Python
使用Python将数组的元素导出到变量中(unpacking)
2016/10/27 Python
Python IDLE 错误:IDLE''s subprocess didn''t make connection 的解决方案
2017/02/13 Python
Python实现求数列和的方法示例
2018/01/12 Python
浅谈Python 敏感词过滤的实现
2019/08/15 Python
python使用协程实现并发操作的方法详解
2019/12/27 Python
python构造函数init实例方法解析
2020/01/19 Python
Python实现aes加密解密多种方法解析
2020/05/15 Python
python 批量将中文名转换为拼音
2021/02/07 Python
使用Filters滤镜弥补CSS3的跨浏览器问题以及兼容低版本IE
2013/01/23 HTML / CSS
HTML5 canvas基本绘图之绘制线段
2016/06/27 HTML / CSS
专业求职信撰写要诀
2014/02/18 职场文书
促销活动总结报告
2014/04/26 职场文书
员工升职自荐信
2015/03/27 职场文书
2015年创先争优工作总结
2015/05/23 职场文书
2015年小学数学教师个人工作总结
2015/05/25 职场文书
电力安全教育培训心得体会
2016/01/11 职场文书
Java 深入探究讲解简单工厂模式
2022/04/07 Java/Android