vue-cli webpack3 扩展多模块打包

场景

在实际的项目开发中会出现这样的场景,项目中需要多个模块(单页或者多页应用)配合使用的情况,而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模块,可以查看文档nodejs.cn/api/fs.html nodejs.cn/api/path.ht…,可以根据自己的项目配置更改,此处是以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
    }
    复制代码

    生产环境下配置与开发环境思路一致,需要注意的是html-webpack-plugin插件参数不同,参考原vue-cli的配置

实战

vue移动web通用脚手架

github地址: github.com/GavinZhuLei…

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值