webpack多页面打包通用方案

1.构建约定:

  1. 所有入口文件按模块划分,并且都放在 src 下
  2. 不同的模块放到不同的模块文件夹下,每个模块的入口文件都命名为index.js


    image.png

2.利用glob 动态根据规则匹配符合条件的所有文件

glob可以允许你通过使用特定的规则找到预制匹配的文件

安装glob

npm install --save-dev glob

使用glob

const path = require('path')
const glob = require('glob')
const pathList = glob.sync(path.join(__dirname, './src/*/index.js'))
console.log(pathList)

输出结果:


image.png

3.根据glob返回的内容设置entry入口和htmlwebpackplugin数组

const entryObj = {}
const htmlArr = []
pathList.forEach(pathStr => {
  let tag = pathStr.match(/src\/(.+)\/index\.js/)[1]
  console.log(tag)
  if (tag) {
    entryObj[tag] = pathStr
    htmlArr.push(
      new HtmlWebpackPlugin({
        template: path.join(__dirname, `src/${tag}/index.html`),
        filename: `${tag}.html`,
        chunks: [`${tag}`]
      }))
  }
})

配置到webpack中

{
    mode: 'development',
    entry: entryObj,
    plugins: htmlArr
}

4.实际效果截图

image.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 16宿命:用概率思维提高你的胜算 以前的我是风险厌恶者,不喜欢去冒险,但是人生放弃了冒险,也就放弃了无数的可能。 ...
    yichen大刀阅读 7,118评论 0 4
  • 公元:2019年11月28日19时42分农历:二零一九年 十一月 初三日 戌时干支:己亥乙亥己巳甲戌当月节气:立冬...
    石放阅读 7,246评论 0 2
  • 今天上午陪老妈看病,下午健身房跑步,晚上想想今天还没有断舍离,马上做,衣架和旁边的的布衣架,一看乱乱,又想想自己是...
    影子3623253阅读 3,043评论 3 8

友情链接更多精彩内容