vue-cli扩展多模块打包的示例代码


Posted in Javascript onApril 09, 2018

场景

在实际的项目开发中会出现这样的场景,项目中需要多个模块(单页或者多页应用)配合使用的情况,而vue-cli默认只提供了单入口打包,所以就想到对vue-cli进行扩展

实现

首先得知道webpack是提供了多入口打包,那就可以从这里开始改造

新建build/entry.js

const path = require('path')
const fs = require('fs')
const moduleDir = path.resolve(__dirname, '../src/modules')
let entryObj = {}
let moduleItems = fs.readdirSync(moduleDir)
moduleItems.forEach(item => {
 entryObj[`${item}`] = `./src/modules/${item}/main.js`

})

module.exports = entryObj

这里用到了nodejs的fs和path模块,可以查看文档http://nodejs.cn/api/fs.html,http://nodejs.cn/api/path.html,可以根据自己的项目配置更改,此处是以src/modules/文件夹下的目录作为模块,每个模块中都有一个main.js作为入口文件

修改build/webpack.base.conf.js中entry

const entryObj = require('./entry')

module.exports = {

 entry: entryObj

}

接下来就是如何将打包好的文件注入到html中,这里利用html-webpack-plugin插件来解决这个问题,首先你需要有一个html的模板文件,然后在webpack配置中更改默认的html-webpack-plugin插件配置

添加build/plugins.js 

const HtmlWebpackPlugin = require('html-webpack-plugin')
let configPlugins = []
Object.keys(entryObj).forEach(item => {
 configPlugins.push(new HtmlWebpackPlugin(
  {

   filename: '../dist/' + item + '.html',

   template: path.resolve(__dirname, '../index.html'),

   chunks: [item]
  }
 ))
})
module.exports = configPlugins

修改build/webpack.dev.conf.js配置 

module.exports = {
  plugins: configPlugins
}

实战

vue移动web通用脚手架

github地址: https://github.com/GavinZhuLei/vue-mobile

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JQuery index()方法使用代码
Jun 02 Javascript
javascript开发中因空格引发的错误
Nov 08 Javascript
js获取触发事件元素在整个网页中的绝对坐标(示例代码)
Dec 13 Javascript
javascript中加号(+)操作符的一些神奇作用
Jun 06 Javascript
2014最热门的JavaScript代码高亮插件推荐
Nov 25 Javascript
详解JavaScript基于面向对象之继承实例
Dec 16 Javascript
JS组件Bootstrap Table使用方法详解
Feb 02 Javascript
react-router中的属性详解
Jun 01 Javascript
浅谈Vue.nextTick 的实现方法
Oct 25 Javascript
JS中appendChild追加子节点无效的解决方法
Oct 14 Javascript
JavaScript实现图片放大镜效果
Jun 27 Javascript
使用vue-router在Vue页面之间传递数据的方法
Jul 15 Javascript
webpack中的热刷新与热加载的区别
Apr 09 #Javascript
vue写一个组件
Apr 09 #Javascript
Vue 中使用 CSS Modules优雅方法
Apr 09 #Javascript
JS中双击和单击事件冲突的解决方法
Apr 09 #Javascript
vue脚手架及vue-router基本使用
Apr 09 #Javascript
vue 设置proxyTable参数进行代理跨域
Apr 09 #Javascript
Angular入口组件(entry component)与声明式组件的区别详解
Apr 09 #Javascript
You might like
PHP新手上路(十四)
2006/10/09 PHP
php stream_get_meta_data返回值
2013/09/29 PHP
php对象和数组相互转换的方法
2015/05/12 PHP
使用swoole 定时器变更超时未支付订单状态的解决方案
2019/07/24 PHP
身份证号码前六位所代表的省,市,区, 以及地区编码下载
2007/04/12 Javascript
ExtJs grid行 右键菜单的两种方法
2010/06/19 Javascript
JS实现的4种数字千位符格式化方法分享
2015/03/02 Javascript
javascript实现连续赋值
2015/08/10 Javascript
简单谈谈javascript中的变量、作用域和内存问题
2015/08/30 Javascript
JavaScript实现仿新浪微博大厅和腾讯微博首页滚动特效源码
2015/09/15 Javascript
AngularJS创建自定义指令的方法详解
2016/11/03 Javascript
JavaScript正则表达式校验与递归函数实际应用实例解析
2017/08/04 Javascript
vue项目中使用fetch的实现方法
2019/04/25 Javascript
微信小程序 搜索框组件代码实例
2019/09/06 Javascript
JS简单表单验证功能完整示例
2020/01/26 Javascript
vue项目中使用多选框的实例代码
2020/07/22 Javascript
JavaScript实现浏览器网页自动滚动并点击的示例代码
2020/12/05 Javascript
[01:13]2014DOTA2西雅图邀请赛 舌尖上的TI4
2014/07/08 DOTA
利用Python的Django框架中的ORM建立查询API
2015/04/20 Python
解决Python 命令行执行脚本时,提示导入的包找不到的问题
2019/01/19 Python
值得收藏的10道python 面试题
2019/04/15 Python
Python+OpenCV+pyQt5录制双目摄像头视频的实例
2019/06/28 Python
简单几步用纯CSS3实现3D翻转效果
2019/01/17 HTML / CSS
Jabra捷波朗美国官网:用于办公、车载和运动的无线蓝牙耳麦
2017/02/01 全球购物
英国现代绅士品牌:Hackett
2017/12/17 全球购物
J2EE是技术还是平台还是框架
2016/08/14 面试题
小学生节约用水倡议书
2014/05/15 职场文书
聘用意向书
2014/07/29 职场文书
小学趣味运动会加油稿
2014/09/25 职场文书
党员评议思想汇报
2014/10/08 职场文书
介绍长城的导游词
2015/01/30 职场文书
入党自荐书范文
2015/03/05 职场文书
简单的辞职信模板
2015/05/12 职场文书
golang通过递归遍历生成树状结构的操作
2021/04/28 Golang
python 下划线的多种应用场景总结
2021/05/12 Python
Java面试题冲刺第十五天--设计模式
2021/08/07 面试题