基于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 相关文章推荐
jquery实现简单的拖拽效果实例兼容所有主流浏览器
Jun 21 Javascript
IE与FF下javascript获取网页及窗口大小的区别详解
Jan 14 Javascript
悬浮数字的实现案例
Feb 19 Javascript
兼容所有浏览器的js复制插件Zero使用介绍
Mar 19 Javascript
jQuery插件multiScroll实现全屏鼠标滚动切换页面特效
Apr 12 Javascript
JQuery 的跨域方法推荐_可跨任何网站
May 18 Javascript
js模式化窗口问题![window.dialogArguments]
Oct 30 Javascript
解决拦截器对ajax请求的拦截实例详解
Dec 21 Javascript
JavaScript中Promise的使用详解
Feb 26 Javascript
图文详解vue框架安装步骤
Feb 12 Javascript
公众号SVG动画交互实战代码
May 31 Javascript
js实现计算器功能
Aug 10 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
php5.2.0内存管理改进
2007/01/22 PHP
ThinkPHP令牌验证实例
2014/06/18 PHP
php内嵌函数用法实例
2015/03/20 PHP
php使用timthumb生成缩略图的方法
2016/01/22 PHP
PHP实现接收二进制流转换成图片的方法
2017/01/10 PHP
PHP与JavaScript针对Cookie的读写、交互操作方法详解
2017/08/07 PHP
PHP面向对象程序设计中的self、static、parent关键字用法分析
2019/08/14 PHP
javascript setTimeout和setInterval计时的区别详解
2013/06/21 Javascript
JavaScript获得当前网页来源页面(即上一页)的方法
2015/04/03 Javascript
在浏览器中打开或关闭JavaScript的方法
2015/06/03 Javascript
简单谈谈javascript中的变量、作用域和内存问题
2015/08/30 Javascript
高效利用Angular中内置服务$http、$location等
2016/03/22 Javascript
jquery拖动层效果插件用法实例分析(附demo源码)
2016/04/28 Javascript
关于JavaScript 原型链的一点个人理解
2016/07/31 Javascript
基于Vue2的移动端开发环境搭建详解
2016/11/03 Javascript
js鼠标移动时禁止选中文字
2017/02/19 Javascript
vue-resouce设置请求头的三种方法
2017/09/12 Javascript
Node.js中package.json中库的版本号(~和^)
2019/04/02 Javascript
Element-ui DatePicker显示周数的方法示例
2019/07/19 Javascript
JavaScript冒泡算法原理与实现方法深入理解
2020/06/04 Javascript
vue深度监听(监听对象和数组的改变)与立即执行监听实例
2020/09/04 Javascript
python静态方法实例
2015/01/14 Python
Django中数据库的数据关系:一对一,一对多,多对多
2018/10/21 Python
python代码编写计算器小程序
2020/03/30 Python
Pytorch释放显存占用方式
2020/01/13 Python
Pytorch之finetune使用详解
2020/01/18 Python
如何在python开发工具PyCharm中搭建QtPy环境(教程详解)
2020/02/04 Python
初中物理教学反思
2014/01/14 职场文书
机修工工作职责
2014/02/21 职场文书
个人简历自荐信
2014/06/26 职场文书
党的群众路线教育实践活动对照检查材料(四风)
2014/09/27 职场文书
学校党的群众路线教育实践活动总结材料
2014/10/30 职场文书
机关工会工作总结2015
2015/05/26 职场文书
MySQL修改默认引擎和字符集详情
2021/09/25 MySQL
JavaScript 中for/of,for/in 的详细介绍
2021/11/17 Javascript
分享node.js实现简单登录注册的具体代码
2022/04/26 NodeJs