场景

在实际的项目开发中会出现这样的场景,项目中需要多个模块(单页或者多页应用)配合使用的情况,而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

最新文章

  1. Android中的 init.rc文件简介
  2. UIScrollView和控制器
  3. grep使用多个查询条件--或
  4. 嵌入式实时操作系统μCOS原理与实践+事件部分代码
  5. SDUT 2603:Rescue The Princess
  6. cocos2d-x 2.2 开发手记2
  7. 说说 DWRUtil
  8. hackerrank [Week of Code 33] Bonnie and Clyde
  9. Linux指令--df,du
  10. 工作流程,编程,调试,性能:Unity游戏开发者应该学习的20个改进技巧
  11. day2 and day3 总结-python基础-坚持就是胜利
  12. C# AsyncCallback异步回调用法示例
  13. (转)区分LTE,EPS,EPC和SAE
  14. Cocos2d-x开源、跨平台的游戏引擎
  15. 第10章:awk进阶操作
  16. [XPath] XPath 与 lxml (三)XPath 坐标轴
  17. 使用webpy创建一个简单的restful风格的webservice应用
  18. Bugzilla使用规范
  19. 谋哥:《App自推广》开篇之回到远古人类
  20. Dubbo之旅--集群容错和负载均衡

热门文章

  1. ssh框架中struts.xml 的配置参数详解
  2. Could not get dialect instance.
  3. epel扩展库的安装
  4. Android Studio报错:the selected directory is not a valid home for unknow sdk
  5. Java日志框架:slf4j作用及其实现原理
  6. java.lang.ClassNotFoundException: org.springframework.web.context.ContextLoaderListene解决办法
  7. python安装第三方库
  8. Maven-09: 在线插件信息
  9. 基于hi-nginx的web开发(python篇)——起步
  10. LeetCode --> 771. Jewels and Stones