Webpack之MPA多页面打包配置(glob)

2023-11-05 09:08

本文主要是介绍Webpack之MPA多页面打包配置(glob),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Webpack配置MPA多页面应用时,需要设置多个入口,并通过html-webpack-plugin配置与之对应的页面。

动态获取入口文件,我们使用glob。

npm i glob --save --dev

glob的用法

var Glob = require("glob");
// pattern : 正则 配置符合条件的文件
// options : 配置参数 一般用来设置文件路径
var fileList = glob.sync(pattern, options)
// fileList: 数组,返回文件绝对路径

我们文件结构如下:

src- index.html- views- home- index.js- system- index.js 
webpack.config.js

文件src下的views目录盛放不同页面,每个页面的入口文件都是index.js

获取所有指定文件:

const fileList = glob.sync(path.join(__dirname,'/src/views/*'))// fileList = ['**/src/views/home','**/src/views/system'];

上述一行,就是我们最重要的代码,后面只需获取文件名、逐文件配置到entry中,并添加在plugins追加文件模版即可。如下可参考:

var HtmlWebpackPlugin = require('html-webpack-plugin');
const path = require('path');
var glob = require("glob");const mpaConfig = () => {const entry = {};const htmlPlugin = [];glob.sync(path.join(__dirname,'/src/views/*')).map(file=>{// 获取文件名称const fileName = file.match(/src\/views\/(.*)/)[1];// 新增入口文件entry[fileName] = `${file}/index.js`;// 新增html文件htmlPlugin.push(new HtmlWebpackPlugin({filename: `${fileName}.html`,template: `${__dirname}/src/index.html`,minify: true}))});return {entry,htmlPlugin,}
};const { entry, htmlPlugin } = mpaConfig();module.exports = {entry,output: {path: `${__dirname}/dist`,filename: '[name]_[chunkhash:8].js'},mode: 'production',plugins: [// ...].concat(htmlPlugin)
};

可根实际情况调整文件目录,over ~

 

这篇关于Webpack之MPA多页面打包配置(glob)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/348800

相关文章

Linux下进程的CPU配置与线程绑定过程

《Linux下进程的CPU配置与线程绑定过程》本文介绍Linux系统中基于进程和线程的CPU配置方法,通过taskset命令和pthread库调整亲和力,将进程/线程绑定到特定CPU核心以优化资源分配... 目录1 基于进程的CPU配置1.1 对CPU亲和力的配置1.2 绑定进程到指定CPU核上运行2 基于

golang程序打包成脚本部署到Linux系统方式

《golang程序打包成脚本部署到Linux系统方式》Golang程序通过本地编译(设置GOOS为linux生成无后缀二进制文件),上传至Linux服务器后赋权执行,使用nohup命令实现后台运行,完... 目录本地编译golang程序上传Golang二进制文件到linux服务器总结本地编译Golang程序

Spring Boot spring-boot-maven-plugin 参数配置详解(最新推荐)

《SpringBootspring-boot-maven-plugin参数配置详解(最新推荐)》文章介绍了SpringBootMaven插件的5个核心目标(repackage、run、start... 目录一 spring-boot-maven-plugin 插件的5个Goals二 应用场景1 重新打包应用

Java中读取YAML文件配置信息常见问题及解决方法

《Java中读取YAML文件配置信息常见问题及解决方法》:本文主要介绍Java中读取YAML文件配置信息常见问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 目录1 使用Spring Boot的@ConfigurationProperties2. 使用@Valu

Jenkins分布式集群配置方式

《Jenkins分布式集群配置方式》:本文主要介绍Jenkins分布式集群配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1.安装jenkins2.配置集群总结Jenkins是一个开源项目,它提供了一个容易使用的持续集成系统,并且提供了大量的plugin满

SpringBoot线程池配置使用示例详解

《SpringBoot线程池配置使用示例详解》SpringBoot集成@Async注解,支持线程池参数配置(核心数、队列容量、拒绝策略等)及生命周期管理,结合监控与任务装饰器,提升异步处理效率与系统... 目录一、核心特性二、添加依赖三、参数详解四、配置线程池五、应用实践代码说明拒绝策略(Rejected

SQL Server配置管理器无法打开的四种解决方法

《SQLServer配置管理器无法打开的四种解决方法》本文总结了SQLServer配置管理器无法打开的四种解决方法,文中通过图文示例介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录方法一:桌面图标进入方法二:运行窗口进入检查版本号对照表php方法三:查找文件路径方法四:检查 S

Linux中SSH服务配置的全面指南

《Linux中SSH服务配置的全面指南》作为网络安全工程师,SSH(SecureShell)服务的安全配置是我们日常工作中不可忽视的重要环节,本文将从基础配置到高级安全加固,全面解析SSH服务的各项参... 目录概述基础配置详解端口与监听设置主机密钥配置认证机制强化禁用密码认证禁止root直接登录实现双因素

嵌入式数据库SQLite 3配置使用讲解

《嵌入式数据库SQLite3配置使用讲解》本文强调嵌入式项目中SQLite3数据库的重要性,因其零配置、轻量级、跨平台及事务处理特性,可保障数据溯源与责任明确,详细讲解安装配置、基础语法及SQLit... 目录0、惨痛教训1、SQLite3环境配置(1)、下载安装SQLite库(2)、解压下载的文件(3)、

Linux如何快速检查服务器的硬件配置和性能指标

《Linux如何快速检查服务器的硬件配置和性能指标》在运维和开发工作中,我们经常需要快速检查Linux服务器的硬件配置和性能指标,本文将以CentOS为例,介绍如何通过命令行快速获取这些关键信息,... 目录引言一、查询CPU核心数编程(几C?)1. 使用 nproc(最简单)2. 使用 lscpu(详细信