详解通用webpack多页面自动导入方案
前言
在之前,我写了一个webpack的模板。在平时我写栗子或者是写几个页面的时候会用到它。当这个模板需要多个页面时需要手动到webpack.config.ts文件中配置entry和HtmlWebpackPlugin,有点麻烦。
思考
我们项目中的页面都是存放在src/pages/*.html中的,我们可以搜索这里文件夹下的html文件我们可以利用node中的glob包中的.sync方法,用来匹配搜索我们想要的文件。将匹配到的文件名自动生成一个entrys对象赋值到webpack.config.ts文件中的entry属性即可。HtmlWebpackPlugin同理。
安装glob
pnpm add glob
创建工具类
在src目录下创建uilts/index.ts文件,引入所需的依赖包(glob、path、html-webpack-plugin)。
src └─uilts └─index.ts
// uilts/index.ts import Glob from 'glob'; import path from 'path'; import HtmlWebpackPlugin from 'html-webpack-plugin';
getEntry
封装getEntry方法,用于搜索页面所引入的脚本文件,该方法需要传入一个匹配规则也就是路径,使用glob包中的.sync方法进行搜索,该方法返回匹配到的数据集。将获奖到的文件名称及路径拼接成entry对象所需的key:value即可,最终getEntry返回一个对象。
export function getEntry(globPath: string): entryObj { const entries: entryObj = { main: './src/main.ts' }; Glob.sync(`${globPath}.ts`).forEach((entry: string) => { const basename: string = path.basename(entry, path.extname(entry)); const pathname: string = path.dirname(entry); entries[basename] = `${pathname}/${basename}`; }); return entries; }
getHtmlWebpackPlugin
封装getHtmlWebpackPlugin方法,用于输出所有匹配到的HtmlWebpackPlugin对象。它同样传入一个匹配规则,匹配所有*.html文件,
export function getHtmlWebpackPlugin(globPath: string): HtmlWebpackPlugin[] { const htmlPlugins: HtmlWebpackPlugin[] = []; Glob.sync(`${globPath}.html`).forEach((entry: string) => { const basename: string = path.basename(entry, path.extname(entry)); const pathname: string = path.dirname(entry); htmlPlugins.push(new HtmlWebpackPlugin({ title: basename, filename: `${basename}.html`, template: `${pathname}/${basename}.html`, chunks: [basename, 'main'], minify: true, })); }); return htmlPlugins; }
二次封装
有了这两个方法之后,在把两个方法再封装成getPages函数.,到时候在webpack.config.ts中调用它就可以直接拿到entry对象和htmlPlugins数组。
interface getPagesType { entries: entryObj, htmlPlugins: HtmlWebpackPlugin[] } export function getPages(pagePath: string): getPagesType { const entries: entryObj = getEntry(pagePath); const htmlPlugins: HtmlWebpackPlugin[] = getHtmlWebpackPlugin(pagePath); return { entries, htmlPlugins, }; }
应用
在webpack.config.ts中使用getPages函数。
引入getPages函数,传入项目中页面所在的路径。使用ES6的解构获奖返回的数据对象。
// webpack.config.ts const { entries, htmlPlugins } = getPages('./src/pages/**/*'); const config: Configuration = { mode: 'development', entry: entries, // ... plugins: [ ...htmlPlugins, ], };
到此这篇关于详解通用webpack多页面自动导入方案的文章就介绍到这了,更多相关webpack多页面自动导入内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
javascript+html5实现仿flash滚动播放图片的方法
这篇文章主要介绍了javascript+html5实现仿flash滚动播放图片的方法,可实现类似Flash滚动播放的效果,非常具有实用价值,需要的朋友可以参考下2015-04-04jquery的.click()点击事件为什么无效,on('click',function())如何使
jquery的.click()点击事件,通常都是可以正常使用的,有时选中的选择器被点击时无法触发回调函数,这是为什么呢?改成on绑定click就可以了吗?面对这样的情况,on('click',function())应该如何使用?2023-08-08JavaScript校验Number(4,1)格式的数字实例代码
这篇文章主要介绍了JavaScript校验Number(4,1)格式的数字实例代码,本文实现思路明确代码简单易懂,非常不错,具有参考借鉴价值,需要的朋友可以参考下2017-03-03
最新评论