web-xiangsonghua/dwt-edp/webpack-edp/webpack.html.js

58 lines
1.4 KiB
JavaScript
Raw Normal View History

2024-12-23 15:13:57 +08:00
let fs = require('fs');
let path = require('path');
let HtmlWebpackPlugin = require('html-webpack-plugin');
let ExtractTextPlugin = require('extract-text-webpack-plugin');
let HtmlWebpackLayoutPlugin = require('html-webpack-layout-plugin');
//------------------------------
// 读取src/js下的页面入口目录
// 除了common和lib外都是各个页面对应的目录
// 构建HtmlWebpackPlugin对象以创建页面
// 其中页面filename为{{目录名称}}.html
// 页面模板为src/view/{{目录名称}}.html
// 页面的chunks只有一个就是[{{目录名称}}]
//------------------------------
let files = fs.readdirSync('./src/js');
let plugins = [];
files.forEach((file) => {
if (file === 'common' || file === 'utils') {
return;
}
// Add start 2018/8/24 17:13 kangzhi
// 更改编译规则,只编译 指定 模块
// if(file !== 'frame' && !/index/.test(file) && !/report-project/.test(file)){
// return;
// }
// Add end 2018/8/24 17:13 kangzhi
// if(!/report/.test(file)){
// return
// }
let filename = (file + '.html');
let opts = {
inject: 'body',
filename: filename,
template: ('./src/view/' + file + '.html'),
chunksSortMode: 'manual',
chunks: [file]
}
opts.layout = ('./src/view/common/layout.html')
plugins.push(new HtmlWebpackPlugin(opts));
})
plugins.push(new HtmlWebpackLayoutPlugin());
module.exports = plugins;