我有Webpack配置,将nunjuck文件编译成html文件。但是,我必须手动指定每个文件的输入和输出。我无法弄清楚如何1)读取给定文件夹中的所有文件和2)将单独的编译文件输出到另一个文件夹,如下所示:
src/file1.njk -> dist/file1.html
src/file2.njk -> dist/file2.html
...
这是我的配置文件:
const path = require("path");
var HtmlWebpackPlugin = require("html-webpack-plugin");
var glob_entries = require("webpack-glob-folder-entries");
// Optional, but highly recommended. Create a returnEntries:
// Webpack doesn't support glob paths. For the nunjucks-html-loader
// we need each path to be specified for it to work (YES, even subdirectories!)
function returnEntries(globPath) {
let entries = glob_entries(globPath, true);
let folderList = new Array();
for (let folder in entries) {
folderList.push(path.join(__dirname, entries[folder]));
}
return folderList;
}
module.exports = {
entry: "./src/app.js",
output: {
filename: "bundle.js",
path: path.resolve(__dirname, "dist")
},
plugins: [
// HtmlWebpackPluginConfig
new HtmlWebpackPlugin({
filename: "index.html",
inject: "body",
template: "nunjucks-html-loader!./src/pages/index.njk"
}),
new HtmlWebpackPlugin({
filename: "1-categorize-devices.html",
inject: "body",
template: "nunjucks-html-loader!./src/pages/1-categorize-devices.njk"
}),
new HtmlWebpackPlugin({
filename: "2-split-to-triggers-vs-actors.html",
inject: "body",
template:
"nunjucks-html-loader!./src/pages/2-split-to-triggers-vs-actors.njk"
}),
new HtmlWebpackPlugin({
filename: "3-generate-all-combinations.html",
inject: "body",
template:
"nunjucks-html-loader!./src/pages/3-generate-all-combinations.njk"
}),
new HtmlWebpackPlugin({
filename: "4-rate-all-combinations.html",
inject: "body",
template: "nunjucks-html-loader!./src/pages/4-rate-all-combinations.njk"
}),
new HtmlWebpackPlugin({
filename: "5-cluster-useful-combinations.html",
inject: "body",
template:
"nunjucks-html-loader!./src/pages/5-cluster-useful-combinations.njk"
}),
new HtmlWebpackPlugin({
filename: "6-scenes-for-given-packages.html",
inject: "body",
template:
"nunjucks-html-loader!./src/pages/6-scenes-for-given-packages.njk"
}),
new HtmlWebpackPlugin({
filename: "7-design-templates.html",
inject: "body",
template: "nunjucks-html-loader!./src/pages/7-design-templates.njk"
}),
new HtmlWebpackPlugin({
filename: "8-functional-prototype.html",
inject: "body",
template: "nunjucks-html-loader!./src/pages/8-functional-prototype.njk"
})
],
module: {
rules: [
{
test: /\.(scss)$/,
use: [
{
// Adds CSS to the DOM by injecting a `<style>` tag
loader: "style-loader"
},
{
// Interprets `@import` and `url()` like `import/require()` and will resolve them
loader: "css-loader"
},
{
// Loader for webpack to process CSS with PostCSS
loader: "postcss-loader",
options: {
plugins: function() {
return [require("autoprefixer")];
}
}
},
{
// Loads a SASS/SCSS file and compiles it to CSS
loader: "sass-loader"
}
]
},
{
// HTML LOADER
// Super important: We need to test for the html
// as well as the nunjucks files
test: /\.html$|njk|nunjucks/,
use: [
"html-loader",
{
loader: "nunjucks-html-loader",
options: {
// Other super important. This will be the base
// directory in which webpack is going to find
// the layout and any other file index.njk is calling.
// searchPaths: [...returnEntries('./src/pages/**/')]
// Use the one below if you want to use a single path.
searchPaths: ["./src/pages"]
}
}
]
}
]
}
};
正如你所看到的,我一直在重复new HtmlWebpackPlugin()
,无法弄清楚如何自动化操作。
非常感谢你。
根据HtmlWebpackPlugin
文档,你在做什么实际上是一个recommended approach(显然很糟糕)。
但你可以做什么,而不是像这样手动逐一列出它们,是写一个帮助函数,它将接受要转换的文件列表(通过glob通配符说)并输出HtmlWebpackPlugin
指令数组,你可以输入直接到webpack
配置。
这只是JS。 Webpack配置只是一个NodeJS脚本。你可以做任何你喜欢的事。